From: "ToBoMi via GitGitGadget" <gitgitgadget@gmail.com>
To: git@vger.kernel.org
Cc: ToBoMi <tobias.boesch@miele.com>, deboeto <tobias.boesch@miele.com>
Subject: [PATCH v2] git gui: add directly calling merge tool from gitconfig
Date: Wed, 28 Aug 2024 08:31:56 +0000 [thread overview]
Message-ID: <pull.1773.v2.git.1724833917245.gitgitgadget@gmail.com> (raw)
In-Reply-To: <pull.1773.git.1724066944786.gitgitgadget@gmail.com>
From: deboeto <tobias.boesch@miele.com>
git gui can open a merge tool when conflicts are
detected (Right click in the diff of the file with
conflicts).
The merge tools that are allowed to
use are hard coded into git gui.
If one wants to add a new merge tool it has to be
added to git gui through a source code change.
This is not convenient in comparison to how it
works in git (without gui).
git itself has configuration options for a merge tools
path and command in the git config.
New merge tools can be set up there without a
source code change.
Those options are used only by pure git in
contrast to git gui. git calls the configured
merge tools directly from the config while git
Gui doesn't.
With this change git gui can call merge tools
configured in the gitconfig directly without a
change in git gui source code.
It needs a configured merge.tool and a configured
mergetool.cmd config entry.
gitconfig example:
[merge]
tool = vscode
[mergetool "vscode"]
path = the/path/to/Code.exe
cmd = \"Code.exe\" --wait --merge \"$LOCAL\" \"$REMOTE\" \"$BASE\" \"$MERGED\"
Without the mergetool.cmd configuration and an
unsupported merge.tool entry, git gui behaves
mainly as before this change and informs the user
about an unsupported merge tool, but now also
shows a hint to add a config entry for the tool
in gitconfig.
If a wrong mergetool.cmd is configured by accident
it is beeing handled by git gui already. In this
case git gui informs the user that the merge tool
couldn't be opened. This behavior is preserved by
this change and should not change.
Beyond compare 3 and Visual Studio code were
tested as manually configured merge tools.
Signed-off-by: Tobias Boesch <tobias.boesch@miele.com>
---
git gui: add directly calling merge tool from gitconfig
cc: Johannes Sixt j6t@kdbg.org
Changes since v1:
* Used existing option mergetool.cmd in gitconfig to trigger the direct
call of the merge tool configured in the config instead adding a new
option mergeToolFromConfig
* Removed assignment of merge tool path to a variable and reused the
already existing one: merget_tool_path
* Changed formatting of the commit message
* Added more context and an examples to the commit message
Published-As: https://github.com/gitgitgadget/git/releases/tag/pr-1773%2FToBoMi%2Fadd_merge_tool_from_config_file-v2
Fetch-It-Via: git fetch https://github.com/gitgitgadget/git pr-1773/ToBoMi/add_merge_tool_from_config_file-v2
Pull-Request: https://github.com/gitgitgadget/git/pull/1773
Range-diff vs v1:
1: 59e8f454a70 ! 1: e77d6dec6c5 git gui: add directly calling merge tool from gitconfig
@@ Metadata
## Commit message ##
git gui: add directly calling merge tool from gitconfig
- * git Gui can open a merge tool when conflicts are
- detected. The merge tools that are allowed to
- call have to be hard coded into git Gui
- althgough there are configuration options for
- merge tools git in the git config. Git calls
- the configured merge tools directly from the
- config while git Gui doesn't.
- * git Gui can now call the tool configured in the
- gitconfig directly.
- * Can be enabled through setting
- gui.mergeToolFromConfig
- * Disabled by default, since option is most likely
- never set
- * bc3 and vscode tested
-
- Signed-off-by: deboeto <tobias.boesch@miele.com>
-
- ## Documentation/config/gui.txt ##
-@@ Documentation/config/gui.txt: gui.blamehistoryctx::
- linkgit:gitk[1] for the selected commit, when the `Show History
- Context` menu item is invoked from 'git gui blame'. If this
- variable is set to zero, the whole history is shown.
-+
-+gui.mergeToolFromConfig::
-+ If true, allow to call the merge tool configured in gitconfig
-+ in git gui directly.
- \ No newline at end of file
+ git gui can open a merge tool when conflicts are
+ detected (Right click in the diff of the file with
+ conflicts).
+ The merge tools that are allowed to
+ use are hard coded into git gui.
+
+ If one wants to add a new merge tool it has to be
+ added to git gui through a source code change.
+ This is not convenient in comparison to how it
+ works in git (without gui).
+
+ git itself has configuration options for a merge tools
+ path and command in the git config.
+ New merge tools can be set up there without a
+ source code change.
+
+ Those options are used only by pure git in
+ contrast to git gui. git calls the configured
+ merge tools directly from the config while git
+ Gui doesn't.
+
+ With this change git gui can call merge tools
+ configured in the gitconfig directly without a
+ change in git gui source code.
+ It needs a configured merge.tool and a configured
+ mergetool.cmd config entry.
+
+ gitconfig example:
+ [merge]
+ tool = vscode
+ [mergetool "vscode"]
+ path = the/path/to/Code.exe
+ cmd = \"Code.exe\" --wait --merge \"$LOCAL\" \"$REMOTE\" \"$BASE\" \"$MERGED\"
+
+ Without the mergetool.cmd configuration and an
+ unsupported merge.tool entry, git gui behaves
+ mainly as before this change and informs the user
+ about an unsupported merge tool, but now also
+ shows a hint to add a config entry for the tool
+ in gitconfig.
+
+ If a wrong mergetool.cmd is configured by accident
+ it is beeing handled by git gui already. In this
+ case git gui informs the user that the merge tool
+ couldn't be opened. This behavior is preserved by
+ this change and should not change.
+
+ Beyond compare 3 and Visual Studio code were
+ tested as manually configured merge tools.
+
+ Signed-off-by: Tobias Boesch <tobias.boesch@miele.com>
## git-gui/lib/mergetool.tcl ##
@@ git-gui/lib/mergetool.tcl: proc merge_resolve_tool2 {} {
@@ git-gui/lib/mergetool.tcl: proc merge_resolve_tool2 {} {
default {
- error_popup [mc "Unsupported merge tool '%s'" $tool]
- return
-+ if {[is_config_true gui.mergetoolfromconfig]} {
-+ set path [get_config mergetool.$tool.path]
-+ set cmdline_config [get_config mergetool.$tool.cmd]
-+ set cmdline_substituted [subst -nobackslashes -nocommands $cmdline_config]
-+ set cmdline [lreplace $cmdline_substituted 0 0 $path]
++ set tool_cmd [get_config mergetool.$tool.cmd]
++ if {$tool_cmd ne {}} {
++ set tool_cmd_file_vars_resolved [subst -nobackslashes -nocommands $tool_cmd]
++ set cmdline [lreplace $tool_cmd_file_vars_resolved 0 0 $merge_tool_path]
+ } else {
-+ error_popup [mc "Unsupported merge tool '%s'" $tool]
++ error_popup [mc "Unsupported merge tool '%s'. Is the tool command and path configured properly in gitconfig?" $tool]
+ return
+ }
}
git-gui/lib/mergetool.tcl | 10 ++++++++--
1 file changed, 8 insertions(+), 2 deletions(-)
diff --git a/git-gui/lib/mergetool.tcl b/git-gui/lib/mergetool.tcl
index e688b016ef6..4c4e8f47bb0 100644
--- a/git-gui/lib/mergetool.tcl
+++ b/git-gui/lib/mergetool.tcl
@@ -272,8 +272,14 @@ proc merge_resolve_tool2 {} {
}
}
default {
- error_popup [mc "Unsupported merge tool '%s'" $tool]
- return
+ set tool_cmd [get_config mergetool.$tool.cmd]
+ if {$tool_cmd ne {}} {
+ set tool_cmd_file_vars_resolved [subst -nobackslashes -nocommands $tool_cmd]
+ set cmdline [lreplace $tool_cmd_file_vars_resolved 0 0 $merge_tool_path]
+ } else {
+ error_popup [mc "Unsupported merge tool '%s'. Is the tool command and path configured properly in gitconfig?" $tool]
+ return
+ }
}
}
base-commit: 159f2d50e75c17382c9f4eb7cbda671a6fa612d1
--
gitgitgadget
next prev parent reply other threads:[~2024-08-28 8:32 UTC|newest]
Thread overview: 19+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-08-19 11:29 [PATCH] git gui: add directly calling merge tool from gitconfig ToBoMi via GitGitGadget
2024-08-24 13:38 ` Johannes Sixt
2024-08-27 12:51 ` AW: " tobias.boesch
2024-08-27 13:53 ` tobias.boesch
2024-08-28 8:31 ` ToBoMi via GitGitGadget [this message]
2024-08-28 17:08 ` [PATCH v2] " Junio C Hamano
2024-09-05 8:09 ` AW: " tobias.boesch
2024-08-31 13:51 ` Johannes Sixt
2024-09-06 6:32 ` AW: " tobias.boesch
2024-09-06 17:43 ` Johannes Sixt
2024-09-06 7:27 ` [PATCH v3] " ToBoMi via GitGitGadget
2024-09-08 12:21 ` Johannes Sixt
2024-09-11 13:41 ` AW: " tobias.boesch
2024-09-11 14:23 ` [PATCH v4] git gui: add directly calling merge tool from configuration ToBoMi via GitGitGadget
2024-09-12 10:17 ` [PATCH v5] " ToBoMi via GitGitGadget
2024-09-14 13:32 ` Johannes Sixt
2024-09-16 8:42 ` AW: " tobias.boesch
2024-11-07 14:16 ` tobias.boesch
2024-11-07 16:43 ` Johannes Sixt
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=pull.1773.v2.git.1724833917245.gitgitgadget@gmail.com \
--to=gitgitgadget@gmail.com \
--cc=git@vger.kernel.org \
--cc=tobias.boesch@miele.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).