是否有一种简单的方法可以删除所有远程对等分支不再存在的跟踪分支?
例子:
分支机构(本地和远程)
主人原始/主起源/bug-fix-a起源/bug-fix-b起源/bug-fix-c
在本地,我只有一个主分支。现在我需要处理bug-fix-a,所以我检查它,处理它,并将更改推到远程。接下来,我对bug-fix-b做同样的操作。
分支机构(本地和远程)
主人bug-fix-abug-fix-b型原始/主起源/bug-fix-a起源/bug-fix-b起源/bug-fix-c
现在我有本地分支机构master,bug-fix-a,bug--fix-b。主分支维护者将把我的更改合并到主分支中,并删除他已经合并的所有分支。
因此,当前状态为:
分支机构(本地和远程)
主人bug-fix-abug-fix-b型原始/主起源/bug-fix-c
现在我想调用一些命令来删除分支(在本例中为bug-fix-a、bug-fix-b),这些分支在远程存储库中不再表示。
它类似于现有命令git remote prune origin,但更类似于git local prune origin。
Windows解决方案
对于Microsoft Windows Powershell:
git结帐主机;git远程更新原点--prune;git branch-vv|选择字符串-模式“:gone]”|%{$_.toString().Trim().Split(“”)[0]}|%{git branch-d$_}
解释
git checkout master切换到master分支
git远程更新原点--修剪远程分支
gitbranch-vv获取所有分支的详细输出(git引用)
选择String-Pattern“:gone]”仅获取从远程删除的记录。
%{$_.toString().Trim().Split(“”)[0]}获取分支名称
%{gitbranch-d$_}删除分支
Windows解决方案
对于Microsoft Windows Powershell:
git结帐主机;git远程更新原点--prune;git branch-vv|选择字符串-模式“:gone]”|%{$_.toString().Trim().Split(“”)[0]}|%{git branch-d$_}
解释
git checkout master切换到master分支
git远程更新原点--修剪远程分支
gitbranch-vv获取所有分支的详细输出(git引用)
选择String-Pattern“:gone]”仅获取从远程删除的记录。
%{$_.toString().Trim().Split(“”)[0]}获取分支名称
%{gitbranch-d$_}删除分支