difftool/mergetool: add diffuse as merge and diff tool

This adds diffuse as a built-in merge tool.

Signed-off-by: Sebastian Pipping <sebastian@pipping.org>
Signed-off-by: David Aguilar <davvid@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Sebastian Pipping
2009-04-06 01:31:23 -07:00
committed by Junio C Hamano
parent 8b7332221d
commit 1c0f3d224e
6 changed files with 14 additions and 11 deletions

View File

@ -27,7 +27,7 @@ OPTIONS
Use the merge resolution program specified by <tool>. Use the merge resolution program specified by <tool>.
Valid merge tools are: Valid merge tools are:
kdiff3, tkdiff, meld, xxdiff, emerge, vimdiff, gvimdiff, ecmerge, kdiff3, tkdiff, meld, xxdiff, emerge, vimdiff, gvimdiff, ecmerge,
tortoisemerge and opendiff diffuse, tortoisemerge and opendiff
+ +
If a merge resolution program is not specified, 'git-mergetool' If a merge resolution program is not specified, 'git-mergetool'
will use the configuration variable `merge.tool`. If the will use the configuration variable `merge.tool`. If the

View File

@ -23,7 +23,7 @@ merge.tool::
Controls which merge resolution program is used by Controls which merge resolution program is used by
linkgit:git-mergetool[1]. Valid built-in values are: "kdiff3", linkgit:git-mergetool[1]. Valid built-in values are: "kdiff3",
"tkdiff", "meld", "xxdiff", "emerge", "vimdiff", "gvimdiff", "tkdiff", "meld", "xxdiff", "emerge", "vimdiff", "gvimdiff",
"ecmerge", tortoisemerge and "diffuse", "ecmerge", "tortoisemerge", and
"opendiff". Any other value is treated is custom merge tool "opendiff". Any other value is treated is custom merge tool
and there must be a corresponding mergetool.<tool>.cmd option. and there must be a corresponding mergetool.<tool>.cmd option.

View File

@ -1174,7 +1174,8 @@ _git_mergetool ()
--tool=*) --tool=*)
__gitcomp " __gitcomp "
kdiff3 tkdiff meld xxdiff emerge kdiff3 tkdiff meld xxdiff emerge
vimdiff gvimdiff ecmerge opendiff vimdiff gvimdiff ecmerge diffuse
opendiff
" "" "${cur##--tool=}" " "" "${cur##--tool=}"
return return
;; ;;

View File

@ -1,7 +1,5 @@
#!/bin/sh #!/bin/sh
# git-difftool-helper is a GIT_EXTERNAL_DIFF-compatible diff tool launcher. # git-difftool-helper is a GIT_EXTERNAL_DIFF-compatible diff tool launcher.
# It supports kdiff3, kompare, tkdiff, xxdiff, meld, opendiff,
# emerge, ecmerge, vimdiff, gvimdiff, and custom user-configurable tools.
# This script is typically launched by using the 'git difftool' # This script is typically launched by using the 'git difftool'
# convenience command. # convenience command.
# #
@ -55,6 +53,10 @@ launch_merge_tool () {
"$merge_tool_path" "$LOCAL" "$REMOTE" "$merge_tool_path" "$LOCAL" "$REMOTE"
;; ;;
diffuse)
"$merge_tool_path" "$LOCAL" "$REMOTE" | cat
;;
vimdiff) vimdiff)
"$merge_tool_path" -d -c "wincmd l" "$LOCAL" "$REMOTE" "$merge_tool_path" -d -c "wincmd l" "$LOCAL" "$REMOTE"
;; ;;
@ -164,9 +166,9 @@ if test -z "$merge_tool"; then
if test -n "$DISPLAY"; then if test -n "$DISPLAY"; then
# If gnome then prefer meld, otherwise, prefer kdiff3 or kompare # If gnome then prefer meld, otherwise, prefer kdiff3 or kompare
if test -n "$GNOME_DESKTOP_SESSION_ID" ; then if test -n "$GNOME_DESKTOP_SESSION_ID" ; then
merge_tool_candidates="meld kdiff3 kompare tkdiff xxdiff gvimdiff" merge_tool_candidates="meld kdiff3 kompare tkdiff xxdiff gvimdiff diffuse"
else else
merge_tool_candidates="kdiff3 kompare tkdiff xxdiff meld gvimdiff" merge_tool_candidates="kdiff3 kompare tkdiff xxdiff meld gvimdiff diffuse"
fi fi
fi fi
if echo "${VISUAL:-$EDITOR}" | grep 'emacs' > /dev/null 2>&1; then if echo "${VISUAL:-$EDITOR}" | grep 'emacs' > /dev/null 2>&1; then

View File

@ -25,8 +25,8 @@ OPTIONS
--tool=<tool>:: --tool=<tool>::
Use the diff tool specified by <tool>. Use the diff tool specified by <tool>.
Valid merge tools are: Valid merge tools are:
kdiff3, kompare, tkdiff, meld, xxdiff, emerge, kdiff3, kompare, tkdiff, meld, xxdiff, emerge, vimdiff, gvimdiff,
vimdiff, gvimdiff, ecmerge, and opendiff ecmerge, diffuse and opendiff
+ +
If a diff tool is not specified, 'git-difftool' If a diff tool is not specified, 'git-difftool'
will use the configuration variable `diff.tool`. If the will use the configuration variable `diff.tool`. If the

View File

@ -414,9 +414,9 @@ fi
if test -z "$merge_tool" ; then if test -z "$merge_tool" ; then
if test -n "$DISPLAY"; then if test -n "$DISPLAY"; then
if test -n "$GNOME_DESKTOP_SESSION_ID" ; then if test -n "$GNOME_DESKTOP_SESSION_ID" ; then
merge_tool_candidates="meld kdiff3 tkdiff xxdiff tortoisemerge gvimdiff" merge_tool_candidates="meld kdiff3 tkdiff xxdiff tortoisemerge gvimdiff diffuse"
else else
merge_tool_candidates="kdiff3 tkdiff xxdiff meld tortoisemerge gvimdiff" merge_tool_candidates="kdiff3 tkdiff xxdiff meld tortoisemerge gvimdiff diffuse"
fi fi
fi fi
if echo "${VISUAL:-$EDITOR}" | grep 'emacs' > /dev/null 2>&1; then if echo "${VISUAL:-$EDITOR}" | grep 'emacs' > /dev/null 2>&1; then