使用git远程修剪原点,我可以删除不在远程上的本地分支。
但是我还想删除从这些远程分支创建的本地分支(检查它们是否未合并会很好)。
我该怎么做呢?
使用git远程修剪原点,我可以删除不在远程上的本地分支。
但是我还想删除从这些远程分支创建的本地分支(检查它们是否未合并会很好)。
我该怎么做呢?
当前回答
Powershell:
git branch -D (git branch --merged |% { $_.trim() } )
其他回答
除了Schleis的答案(它工作得很完美),它还可以集成到Visual Studio中,所以在VS中打开git repo时修剪本地分支非常简单。
您可以使用外部工具功能调用sh.exe (git bash)与特定的目录和命令。它位于工具>外部工具菜单选项中(在VS 2022 17.1.0中)。我使用的参数如下:
命令:{Path-To-Git-Installation-Location} \ bin \ sh.exe
参数:——cd=$(SolutionDir) -c "git fetch -p;Git branch -r | awk '{print $1}' | egrep -v -f /dev/ fg /0 <(Git branch -vv | grep origin) | awk '{print $1}' | xargs Git branch -d"
初始目录:$(SolutionDir)
Git修剪本地分支的截图
值得注意的是,只有当你在VS中打开的解决方案在git repo目录中时,这才会起作用。
最后提醒-这可以通过Visual Studio的按键绑定用户界面在设置>通用>键盘和搜索工具进行按键绑定。ExternalCommand[n],其中n是外部命令表中的位置,您有这个外部工具的位置(它们可以在工具>外部工具对话框中重新排序)。请看下面的截图。
键盘绑定外部工具命令
正如@tzacks所说…有一个NPM包非常方便。只做:
npx git-removed-branches --prune
(我本想评论一下,但名声不够好)
我很确定git remote prune origin是你想要的。
你可以运行它作为git远程剪枝起源-演练,看看它会做什么不做任何改变。
检查目标
$(git分支| grep -Eiv“master|develop|branchYouWantToLive”);执行echo $target;完成
使用for &子命令运行
$(git分支| grep -Eiv“master|develop|branchYouWantToLive”);做git分支-D $target;完成
你可以扩展其他关于分支的东西。
如果要删除所有已经合并到master中的本地分支,可以使用以下命令:
git branch --merged master | grep -v '^[ *]*master$' | xargs git branch -d
如果你使用main作为你的主分支,你应该相应地修改命令:
git branch --merged main | grep -v '^[ *]*main$' | xargs git branch -d
更多信息。