如何查询 git 以找出包含给定提交的分支? gitk
通常会列出分支,除非有太多分支,在这种情况下,它只会显示 “许多(38)” 或类似内容。我需要知道完整列表,或者至少要知道某些分支是否包含提交。
git branch --contains <commit>
仅列出包含指定提交的分支(如果未指定,则为 HEAD)。暗示
--list
。
git branch -r --contains <commit>
还列出远程跟踪分支 (如下面的user3941992的答案所述),即 “与远程分支有直接关系的本地分支”。
另请参阅这篇git ready文章。
--contains
标记将确定是否已将某个提交引入分支。也许您已经从自己认为已应用的补丁中获得了提交 SHA,或者您只是想检查是否可以将您最喜欢的开源项目提交,从而将内存使用减少了 75%。
$ git log -1 tests
commit d590f2ac0635ec0053c4a7377bd929943d475297
Author: Nick Quaranto <nick@quaran.to>
Date: Wed Apr 1 20:38:59 2009 -0400
Green all around, finally.
$ git branch --contains d590f2
tests
* master
注意: 如果提交在远程跟踪分支上 ,请添加-a
选项 。
(如下面的 MichielB评论)
git branch -a --contains <commit>
MatrixFrog注释它仅显示哪些分支包含该确切的提交。
如果您想知道哪些分支包含一个 “等效” 提交(即哪些分支已经选择了该提交),那就是git cherry
:
由于
git cherry
比较更改集而不是提交 ID(sha1) ,因此您可以使用git cherry
来查找您在本地进行的提交是否已在其他提交 ID 下应用了<upstream>
。
例如,如果您通过电子邮件提供<upstream>
补丁程序,而不是直接推送或提取提交,则会发生这种情况。
__*__*__*__*__> <upstream>
/
fork-point
\__+__+__-__+__+__-__+__> <head>
(在这里,标有 ' -
' 的提交不会与git cherry
,这意味着它们已经存在于<upstream>
。)
您可以运行:
git log <SHA1>..HEAD --ancestry-path --merges
从输出中最后一次提交的注释中,您可以找到原始分支名称
例:
c---e---g--- feature
/ \
-a---b---d---f---h---j--- master
git log e..master --ancestry-path --merges
commit h
Merge: g f
Author: Eugen Konkov <>
Date: Sat Oct 1 00:54:18 2016 +0300
Merge branch 'feature' into master