Browse Source

mergetools: add vimdiff3 mode

It's similar to the default, except that the other windows are hidden.
This ensures that removed/added colors are still visible on the main
merge window, but the other windows not visible.

Specially useful with merge.conflictstyle=diff3.

Signed-off-by: Felipe Contreras <felipe.contreras@gmail.com>
Acked-by: David Aguilar <davvid@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
maint
Felipe Contreras 11 years ago committed by Junio C Hamano
parent
commit
7c147b77d3
  1. 1
      mergetools/gvimdiff3
  2. 14
      mergetools/vimdiff
  3. 1
      mergetools/vimdiff3

1
mergetools/gvimdiff3

@ -0,0 +1 @@ @@ -0,0 +1 @@
. "$MERGE_TOOLS_DIR/vimdiff"

14
mergetools/vimdiff

@ -20,16 +20,26 @@ merge_cmd () { @@ -20,16 +20,26 @@ merge_cmd () {
"$merge_tool_path" -f -d -c 'wincmd l' \
"$LOCAL" "$MERGED" "$REMOTE"
;;
gvimdiff3|vimdiff3)
if $base_present
then
"$merge_tool_path" -f -d -c 'hid | hid | hid' \
"$LOCAL" "$REMOTE" "$BASE" "$MERGED"
else
"$merge_tool_path" -f -d -c 'hid | hid' \
"$LOCAL" "$REMOTE" "$MERGED"
fi
;;
esac
check_unchanged
}

translate_merge_tool_path() {
case "$1" in
gvimdiff|gvimdiff2)
gvimdiff|gvimdiff2|gvimdiff3)
echo gvim
;;
vimdiff|vimdiff2)
vimdiff|vimdiff2|vimdiff3)
echo vim
;;
esac

1
mergetools/vimdiff3

@ -0,0 +1 @@ @@ -0,0 +1 @@
. "$MERGE_TOOLS_DIR/vimdiff"
Loading…
Cancel
Save