关闭

Windows下使用Beyond Compare作为git的比对与合并工具

标签: gitBeyond Compare
3448人阅读 评论(0) 收藏 举报
分类:

介绍

其实各种git的GUI客户端都有自带比对工具,但是一开始学Git的时候,用的是Windows下的Git Bash,后来也渐渐熟悉各种命令,用图形客户端反而不习惯了。
这里介绍如何将Beyond Compare配置为git的difftool和mergetool。当需要比对或者合并冲突时,就可以通过difftool和mergetool调用Beyond Compare进行比对和合并冲突了。

操作

目前我电脑里安装的是Beyond Compare 4,就介绍一下4的设置,Beyond Compare 3也是类似的。
其实Beyond Compare官网就有介绍
如何配置git的difftool和mergetool,其实就几行git命令。


#difftool 配置
git config --global diff.tool bc4
git config --global difftool.bc4.cmd "\"c:/program files (x86)/beyond compare 4/bcomp.exe\" \"$LOCAL\" \"$REMOTE\""

#mergeftool 配置
git config --global merge.tool bc4
git config --global mergetool.bc4.cmd "\"c:/program files (x86)/beyond compare 4/bcomp.exe\" \"$LOCAL\" \"$REMOTE\" \"$BASE\" \"$MERGED\""
git config --global mergetool.bc4.trustExitCode true


但是我照着上面的步骤配置,使用difftool命令后,发现左右两边都为空白文件。研究了半天没研究出个所以然。
后来突然想起来用户目录下的.gitconfig看看配置情况,才发现原因。
打开配置文件看到的信息差不多是这样:

[diff]
tool = bc4
[difftool]
prompt = false
[difftool "bc4"]
cmd = \"c:/program files (x86)/beyond compare 4/bcomp.exe\" 

.....


使用git bash是执行上述几个命令后,.gitconfig文件中并没有 \"$LOCAL\" \"$REMOTE\""的影子,所以使用difftool比对文件时,两边都是空白,因为根本就没有传参数进去。
所以换一个思路,不用命令设置,而是直接编辑.gitconfig文件设置,就没问题了。

.gitconfig文件新增如下配置并保存

[diff]
tool = bc4
[difftool]
prompt = false
[difftool "bc4"]
cmd = "\"c:/program files (x86)/beyond compare 4/bcomp.exe\" \"$LOCAL\" \"$REMOTE\""
[merge]
tool = bc
[mergetool]
prompt = false
[mergetool "bc4"]
cmd = "\"c:/program files (x86)/beyond compare 4/bcomp.exe\" \"$LOCAL\" \"$REMOTE\" \"$BASE\" \"$MERGED\""

然后在git命令行中执行相关命令就ok啦:)


#比对当前文件相对于Head版本的改动
git difftool <file_name>

#当merge <branch_name>提示冲突时,执行下面命令便可以调出bc合并冲突
git mergetool


-----------------------------------

我的.getconfig配置:
[user]
	name = paincupid
	email = paincupid@hotmail.com
[diff]
	tool = bc4
[difftool "bc4"]
	cmd = "\"D:\\ProgramData\\BeyondCompare\\Beyond Compare 4-X86/BCompare.exe\" \"$LOCAL\" \"$REMOTE\""
[merge]
	tool = bc4
[mergetool "bc4"]
	cmd = "\"D:\\ProgramData\\BeyondCompare\\Beyond Compare 4-X86/BCompare.exe\" \"$LOCAL\" \"$REMOTE\" \"$BASE\" \"$MERGED\""
	trustExitCode = true

 
1
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:959604次
    • 积分:9616
    • 等级:
    • 排名:第1842名
    • 原创:161篇
    • 转载:292篇
    • 译文:3篇
    • 评论:94条
    最新评论