mirror of
https://github.com/git/git.git
synced 2025-12-12 20:36:24 +01:00
mergetool: new config guiDefault supports auto-toggling gui by DISPLAY
When no merge.tool or diff.tool is configured or manually selected, the selection of a default tool is sensitive to the DISPLAY variable; in a GUI session a gui-specific tool will be proposed if found, and otherwise a terminal-based one. This "GUI-optimizing" behavior is important because a GUI can make a huge difference to a user's ability to understand and correctly complete a non-trivial conflicting merge. Some time ago the merge.guitool and diff.guitool config options were introduced to enable users to configure both a GUI tool, and a non-GUI tool (with fallback if no GUI tool configured), in the same environment. Unfortunately, the --gui argument introduced to support the selection of the guitool is still explicit. When using configured tools, there is no equivalent of the no-tool-configured "propose a GUI tool if we are in a GUI environment" behavior. As proposed in <xmqqmtb8jsej.fsf@gitster.g>, introduce new configuration options, difftool.guiDefault and mergetool.guiDefault, supporting a special value "auto" which causes the corresponding tool or guitool to be selected depending on the presence of a non-empty DISPLAY value. Also support "true" to say "default to the guitool (unless --no-gui is passed on the commandline)", and "false" as the previous default behavior when these new configuration options are not specified. Signed-off-by: Tao Klerks <tao@klerks.biz> Acked-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
ae73b2c8f1
commit
42943b950e
@@ -451,7 +451,7 @@ print_noop_and_exit () {
|
||||
|
||||
main () {
|
||||
prompt=$(git config --bool mergetool.prompt)
|
||||
GIT_MERGETOOL_GUI=false
|
||||
GIT_MERGETOOL_GUI=
|
||||
guessed_merge_tool=false
|
||||
orderfile=
|
||||
|
||||
@@ -511,9 +511,14 @@ main () {
|
||||
|
||||
if test -z "$merge_tool"
|
||||
then
|
||||
if ! merge_tool=$(get_merge_tool)
|
||||
merge_tool=$(get_merge_tool)
|
||||
subshell_exit_status=$?
|
||||
if test $subshell_exit_status = 1
|
||||
then
|
||||
guessed_merge_tool=true
|
||||
elif test $subshell_exit_status -gt 1
|
||||
then
|
||||
exit $subshell_exit_status
|
||||
fi
|
||||
fi
|
||||
merge_keep_backup="$(git config --bool mergetool.keepBackup || echo true)"
|
||||
|
||||
Reference in New Issue
Block a user