美文网首页Git使用常见编程问题锦集
Git对比与合并工具Beyond Compare的配置

Git对比与合并工具Beyond Compare的配置

作者: 炉石不传说 | 来源:发表于2019-06-07 10:23 被阅读32次

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

    #介绍如何将Beyond Compare配置为git的difftool和mergetool。当需要比对或者合并冲突时,就可以通过difftool和mergetool调用Beyond Compare进行比对和合并冲突了。

    把下面命令复制粘贴到Git Bash打开的命令行窗口上,通过没有进行配置文件修改。

    #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

    #让git mergetool不再生成备份文件(*.orig)(此命令是可选的,也可不设置,以后再设置)

    git config --global mergetool.keepBackup false

    但是我照着上面的步骤配置,使用difftool命令后,发现左右两边都为空白文件。研究了半天没研究出个所以然。 后来突然想起来用户目录下(C:\Users\hongkenzhao)的.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>

    git difftool HEAD // 比较当前修改情况

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

    git mergetool

    相关文章

      网友评论

        本文标题:Git对比与合并工具Beyond Compare的配置

        本文链接:https://www.haomeiwen.com/subject/zvlmxctx.html