6

我正在尝试使用 emacs ediff 作为 git difftool。

我遵循了这里提出的一些配置: Using ediff as git mergetool

在比较某个文件的不同 git 修订版之间时,我完全没有问题:ediff 运行良好,并且两个版本之间的差异被正确描述。

但是,当我尝试运行 git difftool 以将文件的当前目录版本与某个 git 修订版进行比较时,我遇到了问题。对于某些文件,我收到以下错误:

apply: Wrong type argument: arrayp, nil

这很奇怪,因为此错误仅针对某些文件,而不是所有文件。

我对几个文件进行了实验,我认为经验法则如下: - 如果要比较的文件没有放在git根目录下,那么它会失败。- 否则,ediff 显示文件的当前版本与指定修订之间的差异,没有任何问题。

我已经尝试过上面提到的链接中解释的一些配置。所有这些都给了我相同的结果: git difftool 在将非根 git 文件的当前目录版本与某个 git 修订版进行比较时失败。

知道如何解决这个问题吗?

非常感谢。-鲍勃

4

1 回答 1

7

Git 知道许多标准的 diff/merge 工具,包括 ediff/emerge。尝试

git config --global diff.tool ediff

并调用它

git difftool --tool=ediffclient master -- <file>

或类似的。ediffclient将使用 emacsclient 而不是启动新的 emacs,我更喜欢 YMMV。

编辑(回应评论):如果 git 抱怨 edifftool,请尝试将以下内容添加到您的全局 git 配置文件($HOME/.gitconfig)中:

[difftool "ediff"]
          cmd = emacs --eval \"(ediff-files \\\"$LOCAL\\\" \\\"$REMOTE\\\")\"
[difftool "ediffclient"]
          cmd = emacsclient --eval \"(ediff-files \\\"$LOCAL\\\" \\\"$REMOTE\\\")\"

我的印象是这些设置是安装的一部分,但也许我错了(或者可能在更新版本的 git 中改变了)。当我找到一些时间时,我会尝试更深入地挖掘。

于 2017-03-06T22:05:58.007 回答