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

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

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

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

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

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

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

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


当前回答

如果您使用的是Github/Github Enterprise,则可以通过点击存储库路径的url/compare来使用Web UI,例如,https://github.com/http4s/http4s/compare.您可以选择要比较的分支/提交/标记:

diff将在github接口的url/compare/{x1}。。。{x2}其中x2和x1是要比较的分支/提交/标记,例如:https://github.com/http4s/http4s/compare/main...dotty

您可以在Github文档中看到更多信息。

其他回答

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

git difftool -d master otherbranch

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

还有一种基于GUI的方法。

你可以使用gitk。

运行:$gitk--全部右键单击分支的提交,然后在弹出菜单中选择标记此提交。右键单击另一个分支的提交,然后选择Diff this->标记的提交或Diff标记的提交->此。

然后,右下面板中会有一个已更改的文件列表,左下面板中有差异详细信息。

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

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

git fetch
git diff origin/master...

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

Try

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

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

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

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

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