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

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

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

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

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

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

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

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


当前回答

注意,如果您不喜欢结果,git可以很容易地尝试合并并避免任何问题。这可能比提前寻找潜在问题更容易。

其他回答

也可以使用视觉差异。

例如,如果您正在使用Sourcetree,您可以在日志视图中选择任意两个提交。

(在大多数情况下,我个人更喜欢使用GUI来实现这一点,我将向那些可能不熟悉GUI选项的人发布这一点。)

当协同工作或同时处理多个功能时,通常上游甚至主功能包含分支中未包含的工作,并且会错误地显示在基本差异中。

如果您的上游可能已经移动,您应该这样做:

git fetch
git diff origin/master...

仅使用gitdiff-master就可以包含或不包含相关更改。

要将当前分支与主分支进行比较,请执行以下操作:

$ git diff --name-status main

要比较任意两个分支:

$ git diff --name-status firstbranch..yourBranchName

在官方文档中有更多的gitdiff选项(特别是--name status选项)。

如果您喜欢GUI并使用Windows,这里有一个简单的方法。

下载WinMerge将两个分支签出到不同的文件夹中使用WinMerge逐个文件夹进行比较。如果其中一个分支是您正在处理的分支,您也可以轻松地进行修改。

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