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:

committed by
Junio C Hamano

parent
8b7332221d
commit
1c0f3d224e
@ -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
|
||||||
|
@ -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.
|
||||||
|
|
||||||
|
@ -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
|
||||||
;;
|
;;
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
Reference in New Issue
Block a user