最近我在使用GitExtension 2.46,但是Git版本是1.9.4.msysgit.2。为了只使用Git命令,我卸载了GitExtension并安装了最新版本的Git和KDiff3。

当我进行合并并且有冲突时,我运行以下命令:

git mergetool

然后我收到了这样的信息:

合并工具kdiff3不能作为'kdiff3'使用。

我猜它肯定是通过KDiff3路径。

环境

操作系统:Windows 10 Git 2.6。1 windows。 KDiff3 0.9.98(64位)

问题:

我必须在.gitconfig文件中配置git mergetool命令,以打开带有冲突文件的LOCAL、REMOTE、BASE和MERGED版本的KDiff3 GUI ? 我如何配置它来使用它作为一个差异工具?


当前回答

与接受的答案相同,但有新的安装路径,便于复制/粘贴:

git config --global merge.tool kdiff3
git config --global mergetool.kdiff3.path "C:/Program Files/KDiff3/kdiff3.exe"
git config --global mergetool.kdiff3.trustExitCode false

git config --global diff.guitool kdiff3
git config --global difftool.kdiff3.path "C:/Program Files/KDiff3/kdiff3.exe"
git config --global difftool.kdiff3.trustExitCode false

其他回答

这些网站非常有用,mergetool和difftool。我使用了全局配置,但是可以被存储库毫无问题地使用。您只需要执行以下命令:

git config --global merge.tool kdiff3
git config --global mergetool.kdiff3.path "C:/Program Files/KDiff3/bin/kdiff3.exe"
git config --global mergetool.kdiff3.trustExitCode false

git config --global diff.guitool kdiff3
git config --global difftool.kdiff3.path "C:/Program Files/KDiff3/bin/kdiff3.exe"
git config --global difftool.kdiff3.trustExitCode false

注意,最新版本kdiff3将可执行文件从应用程序文件夹C:/Program Files/ kdiff3的根目录移动到应用程序文件夹中的bin/文件夹。如果您使用的是旧版本,请从上面的路径中删除“bin/”。

使用trustExitCode选项取决于当diff工具返回时你想做什么。从文档:

Git-difftool在每个文件上分别调用一个diff工具。默认情况下,diff工具报告的错误将被忽略。当调用的diff工具返回非零退出码时,使用——trust-exit-code使git-difftool退出。

我需要添加命令行参数或KDiff3将只打开没有文件,并提示我为基础,本地和远程。我使用了TortoiseHg提供的版本。

此外,我还需要使用老式的DOS 8.3文件名。

[merge]
    tool = kdiff3

[mergetool "kdiff3"]
    cmd = /c/Progra~1/TortoiseHg/lib/kdiff3.exe $BASE $LOCAL $REMOTE -o $MERGED

但是,它现在可以正常工作了。

再延伸一下@Joseph的回答:

应用这些命令后,你的全局.gitconfig文件将有以下几行(为了加快进程,你可以将它们复制到文件中):

[merge]
    tool = kdiff3
[mergetool "kdiff3"]
    path = C:/Program Files/KDiff3/kdiff3.exe
    trustExitCode = false
[diff]
    guitool = kdiff3
[difftool "kdiff3"]
    path = C:/Program Files/KDiff3/kdiff3.exe
    trustExitCode = false

Mac用户

下面是@Joseph接受的答案,但是Mac的默认安装路径为kdiff3

(请注意,您可以复制和粘贴这个,并运行它在一个去)

git config --global merge.tool kdiff3 
git config --global mergetool.kdiff3.path  "/Applications/kdiff3.app/Contents/MacOS/kdiff3" 
git config --global mergetool.kdiff3.trustExitCode false

git config --global diff.guitool kdiff3
git config --global difftool.kdiff3.path "/Applications/kdiff3.app/Contents/MacOS/kdiff3"
git config --global difftool.kdiff3.trustExitCode false

与接受的答案相同,但有新的安装路径,便于复制/粘贴:

git config --global merge.tool kdiff3
git config --global mergetool.kdiff3.path "C:/Program Files/KDiff3/kdiff3.exe"
git config --global mergetool.kdiff3.trustExitCode false

git config --global diff.guitool kdiff3
git config --global difftool.kdiff3.path "C:/Program Files/KDiff3/kdiff3.exe"
git config --global difftool.kdiff3.trustExitCode false