- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
关于 git 的快速问题,特别是 --diff-filter字母,因为它们在使用时出现
git show <rev> --name-status --oneline
.
我注意到在某些文件中,我得到的结果如下:
AM contrib/platform/src/com/sun/jna/platform/win32/WinUser.java
这个文件怎么可能既被添加又被修改?我还得到如下结果:
MM CHANGES.md
这可能是由修改后的提交引起的吗?还有其他可能的原因吗?
谢谢
最佳答案
git show
命令可以显示 merge 提交和非 merge 提交。您正在显示 merge 。
当您要求 git show
显示 merge 提交时,它默认使用“组合差异”。例如,这是 git 源本身中的(部分)提交。我在这里使用了 HEAD^
,因为这个特定的 merge 提交恰好有正确的更改类型来产生有趣的结果。我会先给出例子,然后再解释是怎么回事。
$ git show HEAD^
commit 4109c28e055dba27d73cefb956bea5e611f66ec0
Merge: a3d54f9 e09867f
Author: Junio C Hamano <gitster@pobox.com>
Date: Tue Aug 26 11:16:26 2014 -0700
Merge branch 'jk/diff-tree-t-fix'
让我们添加--name-status --oneline
:
$ git show --name-status --oneline HEAD^
4109c28 Merge branch 'jk/diff-tree-t-fix'
MM combine-diff.c
MM t/t4038-diff-combined.sh
这看起来很像你的,尽管我们只有 MM
而不是 AM
。
现在让我们添加 -m
(这太长了,所以我将它剪下来):
$ git show -m --name-status --oneline HEAD^
4109c28 (from a3d54f9) Merge branch 'jk/diff-tree-t-fix'
M combine-diff.c
M t/t4038-diff-combined.sh
4109c28 (from e09867f) Merge branch 'jk/diff-tree-t-fix'
M .gitignore
M .mailmap
[...]
M column.c
M combine-diff.c
M command-list.txt
[...]
-m
的输出是最容易解释的。 merge 提交是具有两个或更多父项的提交,使用 -m
时,git show
命令会按顺序显示每个父项的提交差异:
... - A - M
/
... - B
此处 merge 提交 M
(4109c28
在 git 源的情况下,此处)具有提交 A
(a3d54f9
) 作为其第一个父级,B
(e09867f
) 作为其第二个。比较A
和M
的内容,我们发现文件combine-diff.c
和t/t4038-diff-combined。 sh
被修改。比较B
和M
的内容,我们发现修改了很多文件,包括combined-diff.c
(并且,在输出中我也删除了 t/t4038-diff-combined.sh
)。
当 git 显示“组合差异”时,它首先过滤掉所有未更改的文件 both parents(或 3 个或更多 parent merge 的“所有 parents”)。也就是说,column.c
从 B
修改为 M
并不被认为是“有趣的”,因为它不是 从 A
修改为 M
。但是 combined-diff.c
在两个单独的 diff 中都发生了变化,因此它保留在组合 diff 中。
如果您添加 --diff-filter
,这将通过仅保留与过滤器匹配的那些差异来进一步减少差异。
在任何情况下,组合的 diff 的“状态”部分显示为一系列状态 es,每个父级一个。这里的序列 AM
表示在 merge 和 first-parent 之间,文件被添加,而在 merge 和 second-parent 之间,文件被修改。您还可以获得 MM
(如上例所示)、MA
(从第一个父级修改,从第二个添加)、MT
和 TM
等。我相当但不完全确定您不会看到重命名和副本(文档说没有分数,只显示一条路径,这对重命名和复制来说是个问题)。在每种情况下,每个字母都有其通常的含义。您在这里看不到任何带有空格作为修改状态字母之一的情况,因为这意味着“没有变化”,并且因为“没有来自某些父项的变化”从组合差异中被丢弃。
有关组合差异的更多信息,请参阅“组合差异格式”部分,例如 the git diff-tree
documentation .
关于git show --name-status 字母 : when can more than one letter appear?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26261351/
我对文档有点困惑。请纠正我。 git 状态- 显示当前本地工作目录状态 git status -u- 显示未跟踪的文件(也是本地的) git 状态 -uno- 不显示未跟踪的文件(也是本地的)?? 后
我有一个具有 12 个虚拟机资源的 ARM 模板。每个虚拟机都有 1 个与其关联的 CustomLinuxScript 扩展资源。 某些 CustomLinuxScript 扩展失败并出现错误:状态文
我有一个具有 12 个虚拟机资源的 ARM 模板。每个虚拟机都有 1 个与其关联的 CustomLinuxScript 扩展资源。 某些 CustomLinuxScript 扩展失败并出现错误:状态文
我有以下 JavaScript 代码: alert(data.status); data 是一个 JSON 对象,其字段之一是 status ( bool 字段)。 当JSON.stringify(d
我在验证表单时遇到此错误,如何解决它。 代码: app.post('/',[ check('username','Error occured in Username').trim().isEmai
我正在开发一个使用 fork() exec() wait() 的 C 程序。第一个进程有以下代码: int main(int argc, const char * argv[]) { // inser
我想在 git status 上运行 linter,但是似乎没有 pre-status 和 post-status Hook 。 如何给 git 添加一个钩子(Hook)? fine docs对此事保
我需要获取所有 current_user.friends 状态,然后按 created_at 对它们进行排序。 class User a.created_at } end current_user.
我在 Eloquent 中使用 orWhere 时遇到问题。 我有一个团队,这个团队有一些资料。我想获取状态 = 1 或状态 = 2 的所有配置文件。但我无法让它工作。 我的代码是这样的: $prof
http://refspecs.linuxfoundation.org/LSB_5.0.0/LSB-Core-generic/LSB-Core-generic.html#INISCRPTACT 根据这
我们在 IIS 6.0 上托管 WCF 服务的服务器之一上观察到以下行为: IIS 日志显示所用时间的值较高 (> 100000) HTTP 状态码是 200 sc-win32-status 代码显示
在 Dynamics CRM 中,潜在客户实体同时具有状态和状态原因。使用 API 我可以获得所有状态原因。我被绊倒的地方是当我的用户选择状态原因时我想倒退并找出哪个状态与所选状态原因相关联。 以下是
我很好奇返回响应和仅创建响应的区别。 我见过大量使用 return res.status(xxx).json(x) 的代码示例和res.status(xxx).json(x) . 谁能详细解释一下两者
文档并没有真正说明 status 是什么。 status 到底是什么? http://man7.org/linux/man-pages/man2/exit_group.2.html 最佳答案 来自ex
An earlier question导致了一些关于如何检查 Git 存储库是否包含脏索引或未跟踪文件的想法。我从那次讨论中采纳的答案如下: #!/bin/sh exit $(git status -
ECSHOP出现 XMlHttpRequest status:[500] Unknow status 这个错误 把/admin/templates/top.htm 这个文件中{insert_scr
我有以下代码用于通过 Twitter4J 获取推文: List statuses; Paging paging = new Paging(1, LIMIT); statuses = twitter.g
非常不言自明。我正在制作一个脚本并且遇到了被使用和解析的情况,但它们的输出似乎总是完全相同。 最佳答案 git status --branch --porcelain "显示分支的状态(ahead,
我有一张表,上面有如下记录 表A subid clickid status datetime 1 123 low 2018-07-24 20:20:44 2 123
如果确实缺少资源,我的 API 将返回以下内容 { "code": 404, "message": "HTTP 404 Not Found" } 当我使用代码 Response.sta
我是一名优秀的程序员,十分优秀!