我想合并两个分开了一段时间的分支,并想知道哪些文件被修改了。

穿过此链接:http://linux.yyz.us/git-howto.html(移动到web.archive.org),这非常有用。

我遇到的比较分支的工具有:

git diff主机。。树枝git日志主机。。树枝git短日志主机。。树枝

我想知道是否有类似于“gitstatus master…branch”的东西来只查看两个分支之间不同的文件。

在不创建新工具的情况下,我认为这是您现在最接近的方法(如果文件被多次修改,这当然会显示重复):

git diff主机。。分支|grep“^diff”

我想知道我是否错过了什么。。。


当前回答

如果您使用IntelliJ IDEA,还可以将任何分支与当前工作分支进行比较。看见http://www.jetbrains.com/idea/webhelp/merging-deleting-and-comparing-branches.html#d288093e3827了解更多信息。这也有免费版。

其他回答

还要记住,git的分支既便宜又容易。如果我认为合并可能有问题,我会为合并创建一个分支。因此,如果master有我想要合并的更改,而ba是我的分支,需要来自master的代码,我可以执行以下操作:

git checkout ba
git checkout -b ba-merge
git merge master
.... review new code and fix conflicts....
git commit
git checkout ba
git merge ba-merge
git branch -d ba-merge
git merge master

最终的结果是,我不得不在一个废弃的分支上尝试合并,然后再使用我的分支。如果我陷入困境,我可以删除ba合并分支,重新开始。

git diff revision_n revision_m

如果revision_n和revision_m是连续提交,则输出与git显示修订版-m

还有一个选项,在这种情况下使用meld:

git difftool -d master otherbranch

这不仅可以看到文件之间的差异,还提供了指向和单击特定文件的简单方法。

Try

$ git diff --stat --color master..branchName

这将为您提供有关每次更改的更多信息,同时仍然使用相同的行数。

如果要以另一种方式合并,还可以翻转分支以获得更清晰的差异图片:

$ git diff --stat --color branchName..master

我制作了一个管道,输出在两个分支之间修改过的所有文件名的列表。这对于管道连接到另一个程序非常有用,而不是直接将差异视为其他响应。

yes n | git difftool main..develop | grep V |sed "s#Viewing ([0-9]*/[0-9]*): ##g"

或者,如果您只想知道当前分支和另一个分支之间的差异:

yes n | git difftool develop | grep V |sed "s#Viewing ([0-9]*/[0-9]*): ##g"

gitdifftooldevelop将提示您打开difftool中的文件。我使用yes n拒绝所有内容,然后简单地用grep和sed格式化文本。