我有一个旧的分支,我想删除它。但是,在这样做之前,我想检查对这个分支的所有提交是否在某个时刻合并到其他分支中。因此,我希望看到所有提交到我的当前分支还没有应用到任何其他分支[或者,如果没有一些脚本是不可能的,如何看到一个分支中的所有提交还没有应用到另一个给定的分支?]。


当前回答

虽然这里发布的一些答案将有助于找到您想要的东西,但git分支的以下子命令是更适合您的任务的解决方案。

——merged用于查找所有可以安全删除的分支,因为这些分支完全包含在HEAD中。

而在master中,可以运行命令来枚举可以安全移除的分支,如下所示:

git branch --merged
  develop
  fpg_download_links
* master
  master_merge_static

# Delete local and remote tracking branches you don't want
git branch -d fpg_download_links
git push origin :fpg_download_links
git branch -d master_merge_static
git push origin :master_merge_static

# There is also a flag to specify remote branches in the output
git branch --remotes --merged

其他回答

jimmyorr的答案不能在Windows上工作。用——not代替^ like so会有帮助:

git log oldbranch --not newbranch --no-merges

对于那些仍然在寻找简单答案的人来说,看看git cherry。它比较实际的差异而不是提交哈希值。这意味着它可以容纳被精心挑选或重基的提交。

首先签出你想要删除的分支:

Git checkout[分支删除]

然后使用git cherry将它与你的主要开发分支进行比较:

Git cherry -v master

示例输出:

+ 8a14709d08c99c36e907e47f9c4dacebeff46ecb Commit message
+ b30ccc3fb38d3d64c5fef079a761c7e0a5c7da81 Another commit message
- 85867e38712de930864c5edb7856342e1358b2a0 Yet another message

注意:-v标志将包括提交消息和SHA散列。

前面带“+”的行在要删除的分支中,但不在主分支中。前面有'-'的在master中有相同的commit。

对于不在master中的JUST提交,将cherry pick和grep结合起来:

git cherry - |大师grep + ^ \ "

示例输出:

+ 8a14709d08c99c36e907e47f9c4dacebeff46ecb Commit message
+ b30ccc3fb38d3d64c5fef079a761c7e0a5c7da81 Another commit message

虽然这里发布的一些答案将有助于找到您想要的东西,但git分支的以下子命令是更适合您的任务的解决方案。

——merged用于查找所有可以安全删除的分支,因为这些分支完全包含在HEAD中。

而在master中,可以运行命令来枚举可以安全移除的分支,如下所示:

git branch --merged
  develop
  fpg_download_links
* master
  master_merge_static

# Delete local and remote tracking branches you don't want
git branch -d fpg_download_links
git push origin :fpg_download_links
git branch -d master_merge_static
git push origin :master_merge_static

# There is also a flag to specify remote branches in the output
git branch --remotes --merged

要查看哪些提交在一个分支而不是另一个分支上的列表,使用git log:

git log --no-merges oldbranch ^newbranch

...也就是说,显示不在newbranch上的oldbranch上的所有提交的提交日志。您可以列出多个分支来包括和排除,例如。

git log  --no-merges oldbranch1 oldbranch2 ^newbranch1 ^newbranch2

注意:在Windows命令提示符中(不是Powershell) ^是一个转义键,所以需要用另一个^进行转义:

git log --no-merges oldbranch ^^newbranch

如果你需要检查的是一个分支,例如,如果你想让分支“B”完全合并到分支“A”中,你可以简单地执行以下操作:

$ git checkout A
$ git branch -d B

git branch -d <branchname>具有“分支必须在HEAD中完全合并”的安全性。

注意:如果分支B合并到A中,这实际上会删除分支B。