6

git 中似乎发生了变化,这使得它不再与 gvim 作为 diff 工具一起正常工作。具体来说,我总是使用 gvim -geometry 标志来最大化窗口。现在,我最终得到了一个空白窗口(空/零行文件)。

4

2 回答 2

5

好的,我找到了答案。为了正常工作,gvim 必须留在前台,而不是像往常一样分叉一个新进程。这是通过在启动 gvim(或 gvimdiff)时使用-for标志来完成的。--nofork

我现在设置了以下有效的别名:

alias gitdg='git difftool --noprompt --extcmd="gvim -d --nofork -geometry 220x80+2000+40" '

请注意单引号和双引号的位置,以使 zsh shell 满意。

我使用 gvim 选项-geometry将差异窗口配置为 220 行 x 80 列。“+2000+40”表示窗口的左上角水平偏移 2000 像素,垂直偏移所有显示器的左上角 80 像素,因此窗口出现在我的 2 显示器设置的右侧显示器上。尝试将其设置-geometry 160x40+60+20为查看更改的效果。

于 2014-10-24T19:33:10.427 回答
3

在 Windows Server 2012R2 上,将以下内容添加到我的 .gitconfig 也对我有用。我的经验是我的设置不需要 -d 和 -f 。即使这是 Windows,请确保您使用正斜杠“/”作为路径信息。

[alias]
    d = difftool
[diff]
    tool = gvimdiff
[difftool]
    prompt = false
[difftool "gvimdiff"]
    path = "C:/Program Files (x86)/Vim/vim81/gvim.exe"

样品运行...

c:\>git d index.html

我还发现我在 _vimrc 中为 diffexpr 定义了一个函数,这需要像这样注释掉......

"set diffexpr=MyDiff()

...它允许“新”内置差异在 gVim 中工作。通过这些更改,一切都在 gui vim 中运行。

于 2018-11-29T15:04:16.340 回答