有没有办法在本地重命名 Git 分支并将其推送到远程分支,即使已经有很多提交推送到远程分支?
或者,是否需要创建一个新的本地分支,删除旧的本地分支,然后在远程仓库上重复操作?
Yes,
特点move
存在以在本地重命名分支
git branch --move <old_name> <new_name>
但要推送它,您必须删除旧的并推送新的
git checkout <new_name>
git push origin [--set-upstream] <new_name>
git push origin --delete <old_name>
--set-upstream
是可选的,它配置新的本地分支来跟踪推送的分支
您可以使用以下简写:
-
本地移动(--move):
git branch -m <old_name> <new_name>
-
推送新分支(--set-upstream,可选):
git push origin [-u] <new_name>
-
删除(--删除):
git push origin -d <old_name>
NB.
感谢 torek 的评论:
顺便说一句,值得一提的是,你应该
- 通知共享上游的其他用户您将这样做,并且
- 按照显示的顺序执行此操作(设置新名称,然后删除旧名称)。
第一个原因是这些用户需要调整。
#2 的原因主要是效率:它避免了必须将对象重新复制到上游存储库,该存储库会在分支删除时删除提交(大多数裸存储库都会这样做,并且大多数接受推送的存储库都是裸存储库)
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)