Merge branch 'ss/mergetool--lib'
* ss/mergetool--lib: mergetool--lib: Add Beyond Compare 3 as a tool mergetool--lib: Sort tools alphabetically for easier lookupmaint
						commit
						9d59e6607a
					
				|  | @ -31,8 +31,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, vimdiff, gvimdiff, | 	araxis, bc3, diffuse, emerge, ecmerge, gvimdiff, kdiff3, | ||||||
| 	ecmerge, diffuse, opendiff, p4merge and araxis. | 	kompare, meld, opendiff, p4merge, tkdiff, vimdiff and xxdiff. | ||||||
| + | + | ||||||
| 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 | ||||||
|  |  | ||||||
|  | @ -26,8 +26,8 @@ OPTIONS | ||||||
| --tool=<tool>:: | --tool=<tool>:: | ||||||
| 	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, | 	araxis, bc3, diffuse, ecmerge, emerge, gvimdiff, kdiff3, | ||||||
| 	diffuse, tortoisemerge, opendiff, p4merge and araxis. | 	meld, opendiff, p4merge, tkdiff, tortoisemerge, vimdiff and xxdiff. | ||||||
| + | + | ||||||
| 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 | ||||||
|  |  | ||||||
|  | @ -33,10 +33,10 @@ merge.stat:: | ||||||
|  |  | ||||||
| merge.tool:: | 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: "araxis", | ||||||
| 	"tkdiff", "meld", "xxdiff", "emerge", "vimdiff", "gvimdiff", | 	"bc3", "diffuse", "ecmerge", "emerge", "gvimdiff", "kdiff3", "meld", | ||||||
| 	"diffuse", "ecmerge", "tortoisemerge", "p4merge", "araxis" and | 	"opendiff", "p4merge", "tkdiff", "tortoisemerge", "vimdiff" | ||||||
| 	"opendiff".  Any other value is treated is custom merge tool | 	and "xxdiff".  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. | ||||||
|  |  | ||||||
| merge.verbosity:: | merge.verbosity:: | ||||||
|  |  | ||||||
|  | @ -1360,7 +1360,7 @@ _git_diff () | ||||||
| } | } | ||||||
|  |  | ||||||
| __git_mergetools_common="diffuse ecmerge emerge kdiff3 meld opendiff | __git_mergetools_common="diffuse ecmerge emerge kdiff3 meld opendiff | ||||||
| 			tkdiff vimdiff gvimdiff xxdiff araxis p4merge | 			tkdiff vimdiff gvimdiff xxdiff araxis p4merge bc3 | ||||||
| " | " | ||||||
|  |  | ||||||
| _git_difftool () | _git_difftool () | ||||||
|  |  | ||||||
|  | @ -10,17 +10,20 @@ merge_mode() { | ||||||
|  |  | ||||||
| translate_merge_tool_path () { | translate_merge_tool_path () { | ||||||
| 	case "$1" in | 	case "$1" in | ||||||
| 	vimdiff|vimdiff2) | 	araxis) | ||||||
| 		echo vim | 		echo compare | ||||||
| 		;; | 		;; | ||||||
| 	gvimdiff|gvimdiff2) | 	bc3) | ||||||
| 		echo gvim | 		echo bcompare | ||||||
| 		;; | 		;; | ||||||
| 	emerge) | 	emerge) | ||||||
| 		echo emacs | 		echo emacs | ||||||
| 		;; | 		;; | ||||||
| 	araxis) | 	gvimdiff|gvimdiff2) | ||||||
| 		echo compare | 		echo gvim | ||||||
|  | 		;; | ||||||
|  | 	vimdiff|vimdiff2) | ||||||
|  | 		echo vim | ||||||
| 		;; | 		;; | ||||||
| 	*) | 	*) | ||||||
| 		echo "$1" | 		echo "$1" | ||||||
|  | @ -46,17 +49,16 @@ check_unchanged () { | ||||||
|  |  | ||||||
| valid_tool () { | valid_tool () { | ||||||
| 	case "$1" in | 	case "$1" in | ||||||
| 	kdiff3 | tkdiff | xxdiff | meld | opendiff | \ | 	araxis | bc3 | diffuse | ecmerge | emerge | gvimdiff | gvimdiff2 | \ | ||||||
| 	vimdiff | gvimdiff | vimdiff2 | gvimdiff2 | \ | 	kdiff3 | meld | opendiff | p4merge | tkdiff | vimdiff | vimdiff2 | xxdiff) | ||||||
| 	emerge | ecmerge | diffuse | araxis | p4merge) |  | ||||||
| 		;; # happy | 		;; # happy | ||||||
| 	tortoisemerge) | 	kompare) | ||||||
| 		if ! merge_mode; then | 		if ! diff_mode; then | ||||||
| 			return 1 | 			return 1 | ||||||
| 		fi | 		fi | ||||||
| 		;; | 		;; | ||||||
| 	kompare) | 	tortoisemerge) | ||||||
| 		if ! diff_mode; then | 		if ! merge_mode; then | ||||||
| 			return 1 | 			return 1 | ||||||
| 		fi | 		fi | ||||||
| 		;; | 		;; | ||||||
|  | @ -89,66 +91,34 @@ run_merge_tool () { | ||||||
| 	status=0 | 	status=0 | ||||||
|  |  | ||||||
| 	case "$1" in | 	case "$1" in | ||||||
| 	kdiff3) | 	araxis) | ||||||
| 		if merge_mode; then |  | ||||||
| 			if $base_present; then |  | ||||||
| 				("$merge_tool_path" --auto \ |  | ||||||
| 					--L1 "$MERGED (Base)" \ |  | ||||||
| 					--L2 "$MERGED (Local)" \ |  | ||||||
| 					--L3 "$MERGED (Remote)" \ |  | ||||||
| 					-o "$MERGED" \ |  | ||||||
| 					"$BASE" "$LOCAL" "$REMOTE" \ |  | ||||||
| 				> /dev/null 2>&1) |  | ||||||
| 			else |  | ||||||
| 				("$merge_tool_path" --auto \ |  | ||||||
| 					--L1 "$MERGED (Local)" \ |  | ||||||
| 					--L2 "$MERGED (Remote)" \ |  | ||||||
| 					-o "$MERGED" \ |  | ||||||
| 					"$LOCAL" "$REMOTE" \ |  | ||||||
| 				> /dev/null 2>&1) |  | ||||||
| 			fi |  | ||||||
| 			status=$? |  | ||||||
| 		else |  | ||||||
| 			("$merge_tool_path" --auto \ |  | ||||||
| 				--L1 "$MERGED (A)" \ |  | ||||||
| 				--L2 "$MERGED (B)" "$LOCAL" "$REMOTE" \ |  | ||||||
| 			> /dev/null 2>&1) |  | ||||||
| 		fi |  | ||||||
| 		;; |  | ||||||
| 	kompare) |  | ||||||
| 		"$merge_tool_path" "$LOCAL" "$REMOTE" |  | ||||||
| 		;; |  | ||||||
| 	tkdiff) |  | ||||||
| 		if merge_mode; then |  | ||||||
| 			if $base_present; then |  | ||||||
| 				"$merge_tool_path" -a "$BASE" \ |  | ||||||
| 					-o "$MERGED" "$LOCAL" "$REMOTE" |  | ||||||
| 			else |  | ||||||
| 				"$merge_tool_path" \ |  | ||||||
| 					-o "$MERGED" "$LOCAL" "$REMOTE" |  | ||||||
| 			fi |  | ||||||
| 			status=$? |  | ||||||
| 		else |  | ||||||
| 			"$merge_tool_path" "$LOCAL" "$REMOTE" |  | ||||||
| 		fi |  | ||||||
| 		;; |  | ||||||
| 	p4merge) |  | ||||||
| 		if merge_mode; then | 		if merge_mode; then | ||||||
| 			touch "$BACKUP" | 			touch "$BACKUP" | ||||||
| 			if $base_present; then | 			if $base_present; then | ||||||
| 				"$merge_tool_path" "$BASE" "$LOCAL" "$REMOTE" "$MERGED" | 				"$merge_tool_path" -wait -merge -3 -a1 \ | ||||||
|  | 					"$BASE" "$LOCAL" "$REMOTE" "$MERGED" \ | ||||||
|  | 					>/dev/null 2>&1 | ||||||
| 			else | 			else | ||||||
| 				"$merge_tool_path" "$LOCAL" "$LOCAL" "$REMOTE" "$MERGED" | 				"$merge_tool_path" -wait -2 \ | ||||||
|  | 					"$LOCAL" "$REMOTE" "$MERGED" \ | ||||||
|  | 					>/dev/null 2>&1 | ||||||
| 			fi | 			fi | ||||||
| 			check_unchanged | 			check_unchanged | ||||||
| 		else | 		else | ||||||
| 			"$merge_tool_path" "$LOCAL" "$REMOTE" | 			"$merge_tool_path" -wait -2 "$LOCAL" "$REMOTE" \ | ||||||
|  | 				>/dev/null 2>&1 | ||||||
| 		fi | 		fi | ||||||
| 		;; | 		;; | ||||||
| 	meld) | 	bc3) | ||||||
| 		if merge_mode; then | 		if merge_mode; then | ||||||
| 			touch "$BACKUP" | 			touch "$BACKUP" | ||||||
| 			"$merge_tool_path" "$LOCAL" "$MERGED" "$REMOTE" | 			if $base_present; then | ||||||
|  | 				"$merge_tool_path" "$LOCAL" "$REMOTE" "$BASE" \ | ||||||
|  | 					-mergeoutput="$MERGED" | ||||||
|  | 			else | ||||||
|  | 				"$merge_tool_path" "$LOCAL" "$REMOTE" \ | ||||||
|  | 					-mergeoutput="$MERGED" | ||||||
|  | 			fi | ||||||
| 			check_unchanged | 			check_unchanged | ||||||
| 		else | 		else | ||||||
| 			"$merge_tool_path" "$LOCAL" "$REMOTE" | 			"$merge_tool_path" "$LOCAL" "$REMOTE" | ||||||
|  | @ -170,75 +140,6 @@ run_merge_tool () { | ||||||
| 			"$merge_tool_path" "$LOCAL" "$REMOTE" | cat | 			"$merge_tool_path" "$LOCAL" "$REMOTE" | cat | ||||||
| 		fi | 		fi | ||||||
| 		;; | 		;; | ||||||
| 	vimdiff|gvimdiff) |  | ||||||
| 		if merge_mode; then |  | ||||||
| 			touch "$BACKUP" |  | ||||||
| 			if $base_present; then |  | ||||||
| 				"$merge_tool_path" -f -d -c "wincmd J" \ |  | ||||||
| 					"$MERGED" "$LOCAL" "$BASE" "$REMOTE" |  | ||||||
| 			else |  | ||||||
| 				"$merge_tool_path" -f -d -c "wincmd l" \ |  | ||||||
| 					"$LOCAL" "$MERGED" "$REMOTE" |  | ||||||
| 			fi |  | ||||||
| 			check_unchanged |  | ||||||
| 		else |  | ||||||
| 			"$merge_tool_path" -R -f -d -c "wincmd l" \ |  | ||||||
| 				"$LOCAL" "$REMOTE" |  | ||||||
| 		fi |  | ||||||
| 		;; |  | ||||||
| 	vimdiff2|gvimdiff2) |  | ||||||
| 		if merge_mode; then |  | ||||||
| 			touch "$BACKUP" |  | ||||||
| 			"$merge_tool_path" -f -d -c "wincmd l" \ |  | ||||||
| 				"$LOCAL" "$MERGED" "$REMOTE" |  | ||||||
| 			check_unchanged |  | ||||||
| 		else |  | ||||||
| 			"$merge_tool_path" -R -f -d -c "wincmd l" \ |  | ||||||
| 				"$LOCAL" "$REMOTE" |  | ||||||
| 		fi |  | ||||||
| 		;; |  | ||||||
| 	xxdiff) |  | ||||||
| 		if merge_mode; then |  | ||||||
| 			touch "$BACKUP" |  | ||||||
| 			if $base_present; then |  | ||||||
| 				"$merge_tool_path" -X --show-merged-pane \ |  | ||||||
| 					-R 'Accel.SaveAsMerged: "Ctrl-S"' \ |  | ||||||
| 					-R 'Accel.Search: "Ctrl+F"' \ |  | ||||||
| 					-R 'Accel.SearchForward: "Ctrl-G"' \ |  | ||||||
| 					--merged-file "$MERGED" \ |  | ||||||
| 					"$LOCAL" "$BASE" "$REMOTE" |  | ||||||
| 			else |  | ||||||
| 				"$merge_tool_path" -X $extra \ |  | ||||||
| 					-R 'Accel.SaveAsMerged: "Ctrl-S"' \ |  | ||||||
| 					-R 'Accel.Search: "Ctrl+F"' \ |  | ||||||
| 					-R 'Accel.SearchForward: "Ctrl-G"' \ |  | ||||||
| 					--merged-file "$MERGED" \ |  | ||||||
| 					"$LOCAL" "$REMOTE" |  | ||||||
| 			fi |  | ||||||
| 			check_unchanged |  | ||||||
| 		else |  | ||||||
| 			"$merge_tool_path" \ |  | ||||||
| 				-R 'Accel.Search: "Ctrl+F"' \ |  | ||||||
| 				-R 'Accel.SearchForward: "Ctrl-G"' \ |  | ||||||
| 				"$LOCAL" "$REMOTE" |  | ||||||
| 		fi |  | ||||||
| 		;; |  | ||||||
| 	opendiff) |  | ||||||
| 		if merge_mode; then |  | ||||||
| 			touch "$BACKUP" |  | ||||||
| 			if $base_present; then |  | ||||||
| 				"$merge_tool_path" "$LOCAL" "$REMOTE" \ |  | ||||||
| 					-ancestor "$BASE" \ |  | ||||||
| 					-merge "$MERGED" | cat |  | ||||||
| 			else |  | ||||||
| 				"$merge_tool_path" "$LOCAL" "$REMOTE" \ |  | ||||||
| 					-merge "$MERGED" | cat |  | ||||||
| 			fi |  | ||||||
| 			check_unchanged |  | ||||||
| 		else |  | ||||||
| 			"$merge_tool_path" "$LOCAL" "$REMOTE" | cat |  | ||||||
| 		fi |  | ||||||
| 		;; |  | ||||||
| 	ecmerge) | 	ecmerge) | ||||||
| 		if merge_mode; then | 		if merge_mode; then | ||||||
| 			touch "$BACKUP" | 			touch "$BACKUP" | ||||||
|  | @ -274,6 +175,114 @@ run_merge_tool () { | ||||||
| 				"$LOCAL" "$REMOTE" | 				"$LOCAL" "$REMOTE" | ||||||
| 		fi | 		fi | ||||||
| 		;; | 		;; | ||||||
|  | 	gvimdiff|vimdiff) | ||||||
|  | 		if merge_mode; then | ||||||
|  | 			touch "$BACKUP" | ||||||
|  | 			if $base_present; then | ||||||
|  | 				"$merge_tool_path" -f -d -c "wincmd J" \ | ||||||
|  | 					"$MERGED" "$LOCAL" "$BASE" "$REMOTE" | ||||||
|  | 			else | ||||||
|  | 				"$merge_tool_path" -f -d -c "wincmd l" \ | ||||||
|  | 					"$LOCAL" "$MERGED" "$REMOTE" | ||||||
|  | 			fi | ||||||
|  | 			check_unchanged | ||||||
|  | 		else | ||||||
|  | 			"$merge_tool_path" -R -f -d -c "wincmd l" \ | ||||||
|  | 				"$LOCAL" "$REMOTE" | ||||||
|  | 		fi | ||||||
|  | 		;; | ||||||
|  | 	gvimdiff2|vimdiff2) | ||||||
|  | 		if merge_mode; then | ||||||
|  | 			touch "$BACKUP" | ||||||
|  | 			"$merge_tool_path" -f -d -c "wincmd l" \ | ||||||
|  | 				"$LOCAL" "$MERGED" "$REMOTE" | ||||||
|  | 			check_unchanged | ||||||
|  | 		else | ||||||
|  | 			"$merge_tool_path" -R -f -d -c "wincmd l" \ | ||||||
|  | 				"$LOCAL" "$REMOTE" | ||||||
|  | 		fi | ||||||
|  | 		;; | ||||||
|  | 	kdiff3) | ||||||
|  | 		if merge_mode; then | ||||||
|  | 			if $base_present; then | ||||||
|  | 				("$merge_tool_path" --auto \ | ||||||
|  | 					--L1 "$MERGED (Base)" \ | ||||||
|  | 					--L2 "$MERGED (Local)" \ | ||||||
|  | 					--L3 "$MERGED (Remote)" \ | ||||||
|  | 					-o "$MERGED" \ | ||||||
|  | 					"$BASE" "$LOCAL" "$REMOTE" \ | ||||||
|  | 				> /dev/null 2>&1) | ||||||
|  | 			else | ||||||
|  | 				("$merge_tool_path" --auto \ | ||||||
|  | 					--L1 "$MERGED (Local)" \ | ||||||
|  | 					--L2 "$MERGED (Remote)" \ | ||||||
|  | 					-o "$MERGED" \ | ||||||
|  | 					"$LOCAL" "$REMOTE" \ | ||||||
|  | 				> /dev/null 2>&1) | ||||||
|  | 			fi | ||||||
|  | 			status=$? | ||||||
|  | 		else | ||||||
|  | 			("$merge_tool_path" --auto \ | ||||||
|  | 				--L1 "$MERGED (A)" \ | ||||||
|  | 				--L2 "$MERGED (B)" "$LOCAL" "$REMOTE" \ | ||||||
|  | 			> /dev/null 2>&1) | ||||||
|  | 		fi | ||||||
|  | 		;; | ||||||
|  | 	kompare) | ||||||
|  | 		"$merge_tool_path" "$LOCAL" "$REMOTE" | ||||||
|  | 		;; | ||||||
|  | 	meld) | ||||||
|  | 		if merge_mode; then | ||||||
|  | 			touch "$BACKUP" | ||||||
|  | 			"$merge_tool_path" "$LOCAL" "$MERGED" "$REMOTE" | ||||||
|  | 			check_unchanged | ||||||
|  | 		else | ||||||
|  | 			"$merge_tool_path" "$LOCAL" "$REMOTE" | ||||||
|  | 		fi | ||||||
|  | 		;; | ||||||
|  | 	opendiff) | ||||||
|  | 		if merge_mode; then | ||||||
|  | 			touch "$BACKUP" | ||||||
|  | 			if $base_present; then | ||||||
|  | 				"$merge_tool_path" "$LOCAL" "$REMOTE" \ | ||||||
|  | 					-ancestor "$BASE" \ | ||||||
|  | 					-merge "$MERGED" | cat | ||||||
|  | 			else | ||||||
|  | 				"$merge_tool_path" "$LOCAL" "$REMOTE" \ | ||||||
|  | 					-merge "$MERGED" | cat | ||||||
|  | 			fi | ||||||
|  | 			check_unchanged | ||||||
|  | 		else | ||||||
|  | 			"$merge_tool_path" "$LOCAL" "$REMOTE" | cat | ||||||
|  | 		fi | ||||||
|  | 		;; | ||||||
|  | 	p4merge) | ||||||
|  | 		if merge_mode; then | ||||||
|  | 		    touch "$BACKUP" | ||||||
|  | 			if $base_present; then | ||||||
|  | 				"$merge_tool_path" "$BASE" "$LOCAL" "$REMOTE" "$MERGED" | ||||||
|  | 			else | ||||||
|  | 				"$merge_tool_path" "$LOCAL" "$LOCAL" "$REMOTE" "$MERGED" | ||||||
|  | 			fi | ||||||
|  | 			check_unchanged | ||||||
|  | 		else | ||||||
|  | 			"$merge_tool_path" "$LOCAL" "$REMOTE" | ||||||
|  | 		fi | ||||||
|  | 		;; | ||||||
|  | 	tkdiff) | ||||||
|  | 		if merge_mode; then | ||||||
|  | 			if $base_present; then | ||||||
|  | 				"$merge_tool_path" -a "$BASE" \ | ||||||
|  | 					-o "$MERGED" "$LOCAL" "$REMOTE" | ||||||
|  | 			else | ||||||
|  | 				"$merge_tool_path" \ | ||||||
|  | 					-o "$MERGED" "$LOCAL" "$REMOTE" | ||||||
|  | 			fi | ||||||
|  | 			status=$? | ||||||
|  | 		else | ||||||
|  | 			"$merge_tool_path" "$LOCAL" "$REMOTE" | ||||||
|  | 		fi | ||||||
|  | 		;; | ||||||
| 	tortoisemerge) | 	tortoisemerge) | ||||||
| 		if $base_present; then | 		if $base_present; then | ||||||
| 			touch "$BACKUP" | 			touch "$BACKUP" | ||||||
|  | @ -286,22 +295,30 @@ run_merge_tool () { | ||||||
| 			status=1 | 			status=1 | ||||||
| 		fi | 		fi | ||||||
| 		;; | 		;; | ||||||
| 	araxis) | 	xxdiff) | ||||||
| 		if merge_mode; then | 		if merge_mode; then | ||||||
| 			touch "$BACKUP" | 			touch "$BACKUP" | ||||||
| 			if $base_present; then | 			if $base_present; then | ||||||
| 				"$merge_tool_path" -wait -merge -3 -a1 \ | 				"$merge_tool_path" -X --show-merged-pane \ | ||||||
| 					"$BASE" "$LOCAL" "$REMOTE" "$MERGED" \ | 					-R 'Accel.SaveAsMerged: "Ctrl-S"' \ | ||||||
| 					>/dev/null 2>&1 | 					-R 'Accel.Search: "Ctrl+F"' \ | ||||||
|  | 					-R 'Accel.SearchForward: "Ctrl-G"' \ | ||||||
|  | 					--merged-file "$MERGED" \ | ||||||
|  | 					"$LOCAL" "$BASE" "$REMOTE" | ||||||
| 			else | 			else | ||||||
| 				"$merge_tool_path" -wait -2 \ | 				"$merge_tool_path" -X $extra \ | ||||||
| 					"$LOCAL" "$REMOTE" "$MERGED" \ | 					-R 'Accel.SaveAsMerged: "Ctrl-S"' \ | ||||||
| 					>/dev/null 2>&1 | 					-R 'Accel.Search: "Ctrl+F"' \ | ||||||
|  | 					-R 'Accel.SearchForward: "Ctrl-G"' \ | ||||||
|  | 					--merged-file "$MERGED" \ | ||||||
|  | 					"$LOCAL" "$REMOTE" | ||||||
| 			fi | 			fi | ||||||
| 			check_unchanged | 			check_unchanged | ||||||
| 		else | 		else | ||||||
| 			"$merge_tool_path" -wait -2 "$LOCAL" "$REMOTE" \ | 			"$merge_tool_path" \ | ||||||
| 				>/dev/null 2>&1 | 				-R 'Accel.Search: "Ctrl+F"' \ | ||||||
|  | 				-R 'Accel.SearchForward: "Ctrl-G"' \ | ||||||
|  | 				"$LOCAL" "$REMOTE" | ||||||
| 		fi | 		fi | ||||||
| 		;; | 		;; | ||||||
| 	*) | 	*) | ||||||
|  | @ -343,7 +360,7 @@ guess_merge_tool () { | ||||||
| 		else | 		else | ||||||
| 			tools="opendiff kdiff3 tkdiff xxdiff meld $tools" | 			tools="opendiff kdiff3 tkdiff xxdiff meld $tools" | ||||||
| 		fi | 		fi | ||||||
| 		tools="$tools gvimdiff diffuse ecmerge p4merge araxis" | 		tools="$tools gvimdiff diffuse ecmerge p4merge araxis bc3" | ||||||
| 	fi | 	fi | ||||||
| 	case "${VISUAL:-$EDITOR}" in | 	case "${VISUAL:-$EDITOR}" in | ||||||
| 	*vim*) | 	*vim*) | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 Junio C Hamano
						Junio C Hamano