- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我在 git 存储库中有一个提交,其中 git show
说只有一个文件被修改,而 git diff
显示两个文件被修改。
我创建了一个简单的示例存储库,它表现出相同的行为。
在示例存储库中,我们有这个简单的历史:
* c248261 (HEAD, origin/master, master) Merged feature into master.
|\
| * d23c497 (feature) Modified fileA and fileB in feature.
* | 06a7f5e Modified fileA and fileC in master.
* | 9cd1a6e Merged feature into master.
|\ \
| |/
| * aed2e5e Modified fileA and fileB in feature.
* | c6e4fe7 Mofified fileC in master.
* | 19ed298 Merged feature to master.
|\ \
| |/
| * c0f2abc Added fileB and modified fileA in feature.
* | 47c67cf Added fileC in master.
|/
* 56a9b73 Added fileA in master.
例如,当我查看提交 c248261 时SourceTree,我可以看到 fileA
和 fileB
被修改了。使用 git diff
得到相同的结果:
$ git diff --name-only c248261^..c248261
fileA
fileB
$
或使用速记符号:
$ git diff --name-only c248261^!
fileA
fileB
$
当我尝试使用 git show
获取相同的信息时,只显示了两个文件之一:
$ git show --name-only c248261
commit c2482616b6b6781d0580ec1008ef7d0ab5f73a70
Merge: 06a7f5e d23c497
Author: ...
Date: Fri Aug 15 16:19:02 2014 +0200
Merged feature into master.
fileA
$
同样,git diff-tree
什么也没显示:
$ git diff-tree c248261
$
有人能解释一下区别吗?
我使用的是 git 版本 2.0.4。
最佳答案
git show
?命令 git show
是一个通用命令,用于显示有关 git
中对象的信息。
来自手册页(git help show
):
Shows one or more objects (blobs, trees, tags and commits).
...
For commits it shows the log message and textual diff.
It also presents the merge commit in a special format as produced by
git diff-tree --cc
...
因此,git show
的输出是不同的,因为这是一个merge 提交而不是一个plain 提交。
git diff-tree --cc
的手册页说:
--cc
This flag changes the way a merge commit patch is displayed, in a
similar way to the -c option. It implies the -c and -p options and
further compresses the patch output by omitting uninteresting hunks whose
the contents in the parents have only two variants and the merge result
picks one of them without modification. When all hunks are uninteresting,
the commit itself and the commit log message is not shown, just like in
any other "empty diff" case.
进一步
-c
This flag changes the way a merge commit is displayed (which means
it is useful only when the command is given one <tree-ish>, or
--stdin). It shows the differences from each of the parents to the
merge result simultaneously instead of showing pairwise diff
between a parent and the result one at a time (which is what the -m
option does). Furthermore, it lists only files which were modified
from all parents.
请注意我在这里重复的最后一行:
Furthermore, it lists only files which were modified from all parents.
因此 git show
merge 提交将仅列出在将提交与 merge 的所有 父项进行比较时修改的文件。对于普通 merge (即 2 个父项),这正是被 merge 的文件。例如,如果您执行此 merge :
git checkout master
git merge feature
git show
列出的文件是在 master
和 feature
之前修改的文件 merge 并在 merge 提交中 merge 在一起。
对于 Octopus merge ——即超过两个父项——生成的文件必须不同于 所有 父项中的文件才能被 git show
显示。
请注意,在 merge 提交中使用 git show
时,其他文件也可能会显示。例如,如果您调用 git merge --no-commit
然后在提交之前执行以下任何操作,那么这些文件也将被 git show
显示在 merge 提交:
git show
正在做的是显示一个所谓的组合差异。
在 merge 提交上运行命令 git show
的结果可以被认为是只显示 merge 的文件,而不是简单地从两个父项之一中获取的未更改文件。
这有点令人惊讶,因为许多人希望看到与您刚刚 merge 到的分支相比哪些文件被修改了。
那么,如果您想查看 parent 双方的差异怎么办?
让我们最后看一下 git show
的手册页:
COMBINED DIFF FORMAT
Any diff-generating command can take the `-c` or --cc option to produce
a combined diff when showing a merge. This is the default format when
showing merges with git-diff(1) or git-show(1). Note also that you can
give the `-m' option to any of these commands to force generation of
diffs with individual parents of a merge.
所以我们可以使用 -m
选项来获得两个差异,如下所示:
git show -m commit
这将一一为您提供与所有 parent 的差异。
要查看 merge 提交与您 merge 到的分支(即第一个父级)上的先前提交之间的区别,请使用以下任一命令:
git show --first-parent commit
git diff commit^..commit
git diff commit^!
--first-parent
选项确实属于 git log
但也适用于 git show
。符号 commit^!
是 commit^..commit
的简写。
要查看 merge 提交和您 merge 的分支之间的区别(例如,查看您从其他分支遗漏的内容),使用
git diff commit^2..commit
符号 commit^2
表示 commit
的第二个父级。
如果您有超过 2 个父项(即 Octopus merge ),我相信您可以猜出如何与第 3、4 等提交进行比较。
关于git - “git show” 不返回与 “git diff” 相同的结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25325348/
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
在编码时,我问了自己这个问题: 这样更快吗: if(false) return true; else return false; 比这个? if(false) return true; return
如何在逻辑条件下进行“返回”? 在这样的情况下这会很有用 checkConfig() || return false; var iNeedThis=doSomething() || return fa
这是我的正则表达式 demo 如问题所述: 如果第一个数字是 1 则返回 1 但如果是 145 则返回 145 但如果是 133 则返回 133 样本数据a: K'8134567 K'81345678
在代码高尔夫问答部分查看谜题和答案时,我遇到了 this solution返回 1 的最长和最晦涩的方法 引用答案, int foo(void) { return! 0; } int bar(
我想在下面返回 JSON。 { "name": "jackie" } postman 给我错误。说明 Unexpected 'n' 这里是 Spring Boot 的新手。 1日龄。有没有正确的方法来
只要“is”返回 True,“==”不应该返回 True 吗? In [101]: np.NAN is np.nan is np.NaN Out[101]: True In [102]: np.NAN
我需要获取所有在 6 号或 7 号房间或根本不在任何房间的学生的详细信息。如果他们在其他房间,简单地说,我不希望有那个记录。 我的架构是: students(roll_no, name,class,.
我有一个表单,我将它发送到 php 以通过 ajax 插入到 mysql 数据库中。一切顺利,php 返回 "true" 值,但在 ajax 中它显示 false 消息。 在这里你可以查看php代码:
我在 Kotlin 中遇到了一个非常奇怪的无法解释的值比较问题,以下代码打印 假 data class Foo ( val a: Byte ) fun main() { val NUM
请注意,这并非特定于 Protractor。问题在于 Angular 2 的内置 Testability service Protractor 碰巧使用。 Protractor 调用 Testabil
在调试窗口中,以下表达式均返回 1。 Application.WorksheetFunction.CountA(Cells(4 + (i - 1) * rows_per_record, 28) & "
我在本地使用 jsonplaceholder ( http://jsonplaceholder.typicode.com/)。我正在通过 extjs rest 代理测试我的 GET 和 POST 调用
这是 Postman 为成功调用我的页面而提供的(修改后的)代码段。 var client = new RestClient("http://sub.example.com/wp-json/wp/v2
这个问题在这里已经有了答案: What to do with mysqli problems? Errors like mysqli_fetch_array(): Argument #1 must
我想我对 C 命令行参数有点生疏。我查看了我的一些旧代码,但无论这个版本是什么,都会出现段错误。 运行方式是 ./foo -n num(其中 num 是用户在命令行中输入的数字) 但不知何故它不起作用
我已经编写了一个类来处理命名管道连接,如果我创建了一个实例,关闭它,然后尝试创建另一个实例,调用 CreateFile() 返回 INVALID_HANDLE_VALUE,并且 GetLastErro
即使 is_writable() 返回 true,我也无法写入文件。当然,该文件存在并且显然是可读的。这是代码: $file = "data"; echo file_get_contents($fil
下面代码中的变量 $response 为 NULL,尽管它应该是 SOAP 请求的值。 (潮汐列表)。当我调用 $client->__getLastResponse() 时,我从 SOAP 服务获得了
我一直在网上的不同论坛上搜索答案,但似乎没有与我的情况相符的... 我正在使用 Windows 7,VS2010。 我有一个使用定时器来调用任务栏刷新功能的应用程序。在该任务栏函数中包含对 LoadI
我是一名优秀的程序员,十分优秀!