diff options
author | Charles Bailey <cbailey32@bloomberg.net> | 2014-10-11 01:39:38 -0700 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2014-10-15 14:12:20 -0700 |
commit | 4fb4b02d98310f4f859f7d52f57f36d49198be5c (patch) | |
tree | e0d306e3100bb5f6c19dbe70d44898082b52cbb8 /git-difftool.perl | |
parent | 7bfb7c357cd33a9f3a72d65b0df96e054d2a9f06 (diff) | |
download | git-4fb4b02d98310f4f859f7d52f57f36d49198be5c.tar.gz |
difftool: don't assume that default sh is saneda/mergetool-tool-help
git-difftool used to create a command list script containing $( ... )
and explicitly calls "sh -c" with this list.
Instead, allow mergetool --tool-help to take a mode parameter and call
mergetool directly to invoke the show_tool_help function. This mode
parameter is intented for use solely by difftool.
Signed-off-by: Charles Bailey <cbailey32@bloomberg.net>
Helped-by: John Keeping <john@keeping.me.uk>
Signed-off-by: David Aguilar <davvid@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'git-difftool.perl')
-rwxr-xr-x | git-difftool.perl | 6 |
1 files changed, 1 insertions, 5 deletions
diff --git a/git-difftool.perl b/git-difftool.perl index 18ca61e8d0..598fcc23b9 100755 --- a/git-difftool.perl +++ b/git-difftool.perl @@ -47,13 +47,9 @@ sub find_worktree sub print_tool_help { - my $cmd = 'TOOL_MODE=diff'; - $cmd .= ' && . "$(git --exec-path)/git-mergetool--lib"'; - $cmd .= ' && show_tool_help'; - # See the comment at the bottom of file_diff() for the reason behind # using system() followed by exit() instead of exec(). - my $rc = system('sh', '-c', $cmd); + my $rc = system(qw(git mergetool --tool-help=diff)); exit($rc | ($rc >> 8)); } |