在做了一个“简单的”合并(没有冲突)之后,git show通常只显示如下内容

commit 0e1329e551a5700614a2a34d8101e92fd9f2cad6 (HEAD, master)
Merge: fc17405 ee2de56
Author: Tilman Vogel <email@email>
Date:   Tue Feb 22 00:27:17 2011 +0100

Merge branch 'testing' into master

这是因为,对于合并,git show使用组合的diff格式,省略了与父版本一致的文件。

有没有办法强制git在组合diff模式下仍然显示所有差异?

执行git show -m将显示差异(分别使用新版本和所有父版本之间的两两差异),但我更喜欢在组合模式中,在各自的列中用+/-标记差异。


当前回答

如果你的合并提交是commit 0e1329e5,如上所述,你可以通过以下方式获得包含在合并中的diff:

git diff 0e1329e5^..0e1329e5

我希望这能有所帮助!

其他回答

一个更好的解决方案(@KrisNuttycombe提到过):

git diff fc17405...ee2de56

对于合并提交:

commit 0e1329e551a5700614a2a34d8101e92fd9f2cad6 (HEAD, master)
Merge: fc17405 ee2de56
Author: Tilman Vogel <email@email>
Date:   Tue Feb 22 00:27:17 2011 +0100

显示从fc17405上的提交可以到达的ee2de56上的所有更改。注意提交哈希的顺序-它与合并信息中显示的相同:merge: fc17405 ee2de56

还要注意这3个点…而不是两个!

对于已更改文件的列表,您可以使用:

git diff fc17405...ee2de56 --name-only

这里似乎回答了: https://public-inbox.org/git/7vd392ezhx.fsf@alter.siamese.dyndns.org/

同理,跑步 $ git diff——cc $M $M^1 $M^2 $(git merge-base $M^1 $M^2) 应该显示一个组合补丁,解释在$M相对于 在父节点和合并基节点中记录的状态。

可以使用带-c标志的diff-tree命令。这个命令显示合并提交中更改了哪些文件。

git diff-tree -c {merged_commit_sha}

我从Git-Scm中得到了-c标志的描述:

这个标志改变了合并提交的显示方式 仅当命令中有——stdin)时才有用。 它显示了每个父节点与合并结果之间的差异 同时,而不是显示父母之间的差异 每次一个结果(这就是-m选项所做的)。 此外,它只列出从所有父级修改过的文件。

在你的情况下,你只需要

git diff HEAD^ HEAD^2

或者只是为你提交哈希:

git diff 0e1329e55^ 0e1329e55^2

如果你正在进行合并提交,那么这将显示差异:

git差别头~1..头

如果你不在合并提交,那么就用合并提交替换HEAD。这种方法似乎是最简单、最直观的。