由于我在 Windows 7 上并且确实使用了 SourceGear 的 DiffMerge 工具,因此我一直在遵循此答案中“ Dave 的博客条目”链接中的指示。我已将目录添加到我的 PATH 系统变量并将我的文件放在那里:git\cmd
git-diff-diffmerge-wrapper.sh
#!/bin/sh
"C:\Program Files\SourceGear\Common\DiffMerge\sgdm.exe" "$1" "$2" | cat
(是的,这是 DiffMerge 的正确路径。)
我已经编辑了我的.gitconfig
文件以包含diff
和difftool
块(我直接从帖子中复制了这些行,他确实留在了注释掉的#external
行中。我将此添加到我的文件末尾;可以吗?)
[diff]
# external = git-diff-wrapper.sh
tool = diffmerge
[difftool "diffmerge"]
cmd = git-diff-diffmerge-wrapper.sh "$LOCAL" "$REMOTE"
所以我去做,git bash
然后按git difftool HEAD~ 67b8679 -- js/site/pizzabuilder.js
回车。什么都没发生。如果我这样做git difftool HEAD~ 67b8679
,离开我想要的文件,我会得到这个:
Viewing: 'js/angular/hutlovers/hutlovers.js'
Launch 'diffmerge' [Y/n]: Y
C:\Program Files (x86)\Git/libexec/git-core/mergetools/defaults: line 17: git-diff-diffmerge-wrapper.sh: command not found
Viewing: 'js/angular/localization/StoreListCtrl.js'
Launch 'diffmerge' [Y/n]: n
Viewing: 'js/pizzahut/site/browser_version.js'
Launch 'diffmerge' [Y/n]: n
Viewing: 'js/pizzahut/site/dashboard.js'
Launch 'diffmerge' [Y/n]: n
它继续处理提交之间不同的所有文件,但它从不启动 DiffMerge。我不知道如何解释错误;什么命令没有找到?difftool
? 我在 git 中运行 1.7.11,difftool
据说从 1.6.3 版开始包含在 git 中。
当我查看错误中引用的文件的第 17 行时,这就是那里的内容:
( eval $merge_tool_cmd )
作为此块的一部分:
diff_cmd () {
merge_tool_cmd="$(get_merge_tool_cmd "$1")"
if test -z "$merge_tool_cmd"
then
status=1
break
fi
( eval $merge_tool_cmd )
status=$?
return $status
}
谁能帮我吗?我是 的日常用户git
,但几乎不是超级用户,而且我对 Windows shell 脚本一无所知,所以按照那篇文章中的说明进行操作几乎是我目前知识的局限。