我有一个名为Test_Branch的分支。当我尝试使用推荐方法删除它时,我得到以下错误:
无法删除在'[目录签出的分支'Test_Branch' 位置]。
除此之外,我没有得到其他信息。我可以轻易地吹走远程分支,但本地分支不会消失。
我有一个名为Test_Branch的分支。当我尝试使用推荐方法删除它时,我得到以下错误:
无法删除在'[目录签出的分支'Test_Branch' 位置]。
除此之外,我没有得到其他信息。我可以轻易地吹走远程分支,但本地分支不会消失。
当前回答
如果你遇到这个问题,你已经签出,不能删除分支,并得到这个错误消息
"错误:无法删除分支'issue-123'在.....上签出"
然后通过使用检查您当前所在的分支 git分支
如果要删除的分支是当前分支,则不能删除相同的分支。只要切换到主或主或任何其他分支,然后尝试删除
Git主签或主签
Git branch -d branchname git branch -D branchname git branch -D branchname——force
其他回答
在我的例子中,来自前一个分支的未提交的更改仍然存在。我使用以下命令,然后删除工作。
git checkout *
git checkout master
git branch -D <branch name>
今天git branch -a报告的分支遇到了这个问题,看起来像这样:remotes/coolsnake/dev,即在注册的git remote add中对“远程”分支的本地引用…遥控器。
当你尝试
git branch -d remotes/coolsnake/dev
你会得到这样的错误:branch 'remotes/coolsnake/dev' not found。
神奇的是要记住,这些是引用,必须删除通过
git update-ref -d remotes/coolsnake/dev
(as https://superuser.com/questions/283309/
我花了一段时间才发现我的错误,只有TortoiseGit可以做到这一点,当我陷入困境时,我才走上了正确的道路。谷歌没有提供任何有用的东西,尽管有几种不同的方法。(不,我已经找到了我需要的东西,还有git:如何删除一个本地引用分支?,这并没有显示,因为我已经忘记了这些分支是引用的“ref”位。)
希望这能帮助其他人摆脱困境,当他们和我在同一条船上时,试图过滤/选择性地删除repo中的一些分支,其中一些由于之前的git远程添加命令而存在。
在shell脚本中,这可能是这样的:
#! /bin/bash
#
# Remove GNU/cesanta branches so we cannot accidentally merge or cherrypick from them!
#
# commit hash is first GNU commit
R=218428662e6f8d30a83cf8a89f531553f1156d25
for f in $( git tag -l ; git branch -a ) ; do
echo "$f"
X=$(git merge-base $R "$f" )
#echo "X=[$X]"
if test "$X" = "$R" ; then
echo GNU
git branch -D "$f"
git update-ref -d "refs/$f"
git tag -d "$f"
#git push origin --delete "$f"
else
echo CIVETWEB
fi
done
git branch --D branch-name
请运行此代码删除
我有一个类似的问题,除了坏的分支是在rebase中间。 Git checkout bad_branch && Git rebase—abort解决了我的问题。
今天遇到了这个问题,换到另一个分支也没有帮助。结果是我的工作树信息被损坏了,有一个工作树与我的工作目录具有相同的文件夹路径,头部指向分支(git工作树列表)。我删除了引用它的.git/worktree/文件夹,git分支-d工作了。