我目前正在使用以下命令设置Meld difftool在Babun中工作:
git config --global diff.tool meld
git config --global difftool.prompt false
git config --global difftool.meld.path "/cygdrive/c/Program\ Files\ \(x86\)/Meld/Meld.exe"
git config --global difftool.meld.cmd '/cygdrive/c/Program\ Files\ \(x86\)/Meld/Meld.exe $LOCAL $REMOTE'
这很有效,当我运行
时,Meld会打开两个文件git difftool HEAD HEAD^
然而,第二个文件(来自遥控器)没有打开,我得到了
There was a problem opening the file "\tmp\xxx_FILENAME.EXTENSION"
然而,当我从git bash运行difftool时,它可以工作。我的设置有问题吗?
答案 0 :(得分:6)
问题是从Cygwin访问临时文件。因为Cygwin有自己的驱动器,所以我需要使用cygpath
来格式化文件路径。完整设置如下:
git config --global diff.tool meld
git config --global difftool.prompt false
git config --global difftool.meld.path "c:\Program Files (x86)\Meld\Meld.exe"
git config --global difftool.meld.cmd 'c:/Program\ Files\ \(x86\)/Meld/Meld.exe "$(cygpath -w "$LOCAL")" "$(cygpath -w "$REMOTE")"'