即使删除了其上游远程分支,git remote prune origin也不会删除本地分支

时间:2018-02-16 05:32:41

标签: git git-branch git-remote

这是我的一个常见用例,我克隆一个存储库,签出一个分支,执行一些代码更改,进行多次提交,然后当它稳定时,我会推送到远程,最终分支被合并并删除。我离开了一个当地的分支,上游消失了。

我一直在寻找一种删除所有此类分支的安全方法。从描述来看,似乎git remote prune起源正是这样做的。但它似乎对我不起作用。

看到以下行为,分支encrdb_init已从remote中删除,但git remote prune origin命令似乎无法修剪它。我不知道为什么。

$ git branch
  bugfix/encrdb_init
  * master
$
$ git remote prune origin
$
$ git checkout bugfix/encrdb_init
  Switched to branch 'bugfix/encrdb_init'
  Your branch is based on 'origin/bugfix/encrdb_init', but the upstream 
  is gone.
  (use "git branch --unset-upstream" to fixup)
$
$ git branch
  bugfix/encrdb_init <<< shouldn't this have been pruned?
  * master

用于参考添加git remote show origin

的输出
$ git remote show origin
* remote origin
  Fetch URL: <redacted>
  Push  URL: <redacted>
  HEAD branch: master
  Remote branches:
    SSL_test                                                  tracked
    addNodeFix                                                tracked
    autoprefix                                                tracked
    release/1.0.2                                             tracked
  Local branches configured for 'git pull':
    bugfix/encrdb_init          merges with remote bugfix/encrdb_init
    master                      merges with remote master
    release/1.0.2               merges with remote release/1.0.2
  Local refs configured for 'git push':
    master                 pushes to master                 (up to 
date)
    release/1.0.2          pushes to release/1.0.2          (up to 
date)

$ git branch -vv
* bugfix/encrdb_init          341a078c [origin/bugfix/encrdb_init: gone] <redacted comment>`

1 个答案:

答案 0 :(得分:7)

git remote prune 命令仅删除remotes/origin命名空间中的远程跟踪分支。

不是当地的分支机构 通常的做法是delete only merged local branches

git branch(即使使用-vv)只显示本地分支 一个branch can have a slash in its name

远程跟踪分支位于remotes/origin命名空间中,并记录获取的内容 upstream branch 是与本地分支关联的远程分支,以便所述本地分支知道 要推送的位置。

git remote prune正确删除远程跟踪分支,该分支恰好是本地bugfix/encrdb_init分支的上游分支。
这就是为什么你看到origin/bugfix/encrdb_init: gone:远程跟踪分支已经消失。

OP补充道:

  

从描述中可以看出git remote prune origin正是这样做的。但它似乎对我不起作用。

不,描述中没有提到本地分支。

  

删除<name>下的所有陈旧远程跟踪分支   这些陈旧的分支已从<name>引用的远程存储库中删除,但仍在“remotes/<name>”中本地可用。

<name>这里是git remote -v引用的远程仓库的名称。
通常是“origingit remote prune将删除remotes/origin中注册的分支(不是“远程”)。它不会删除本地分支。

要“安全地”删除本地分支,您应该:

最后一个选项是不稳定的:

  • 我更喜欢使用git branch -d而不是-D,以便只删除已经合并的分支。
  • 您最终可能会删除包含字符串“: gone
  • 的提交消息的分支

A better way to list those branches is

git branch --list --format "%(if:equals=[gone])%(upstream:track)%(then)%(refname)%(end)"