我在Git中有一个存储库。我做了一个分支,然后对主分支和分支都做了一些更改。
然后,几十次提交之后,我意识到分支的状态比主分支好得多,所以我希望分支“成为”主分支,并忽略对主分支的更改。
我无法合并它,因为我不想将更改保留在master上。我该怎么办?
额外:在本例中,“旧”主控已被推送到另一个存储库,如GitHub。这是如何改变事情的?
我在Git中有一个存储库。我做了一个分支,然后对主分支和分支都做了一些更改。
然后,几十次提交之后,我意识到分支的状态比主分支好得多,所以我希望分支“成为”主分支,并忽略对主分支的更改。
我无法合并它,因为我不想将更改保留在master上。我该怎么办?
额外:在本例中,“旧”主控已被推送到另一个存储库,如GitHub。这是如何改变事情的?
当前回答
我知道这不是OP想要的,但如果你知道你将来会遇到与OP类似的问题,你可以这样做。
这是你的情况,
您需要一个分支,它具有新的优秀的新中断功能,但目前还没有推出。你有计划在未来推动它。您当前的prod分支(master)运行良好,但很无聊。你可以对它做一些小改动。如果以后需要,您希望保持当前主(prod)分支的安全。
如果这让人感到困惑,请参见下图中的糟糕情况。
*bad situation*
initial master ---> added boring changes ----merge---> you loose boring
\ /
---> (awesome branch) added awesome changes ---
要解决此问题(即停止钻孔损失),请执行以下操作大体上
通过执行git branch boring创建当前主控形状的副本将boring替换为要保留的任何名称现在,您可以向主分支添加新的很棒的功能,并向无聊分支添加无聊的功能。您仍然可以继续更新枯燥的分支,并可能使用它来永远不会将其合并到master。你不会失去乏味的功能。你的主分支将有很棒的功能。
So,
*good situation*
initial master ---> added awesome changes ---> Final master(awesome) branch
\
---> (boring branch) added boring changes ---> Dont merge to master --X-->
其他回答
这里给出的解决方案(在“master”中重命名分支)并不坚持远程(GitHub)回购的后果:
如果在创建该分支之后没有推送任何内容,那么可以重命名它并推送它,而不会有任何问题。如果你在GitHub上有push master,你需要“git push-f”新分支:你不能再以快进模式进行push了。
-f --force
通常,该命令拒绝更新远程引用,该远程引用不是用于覆盖它的本地引用的祖先。此标志禁用检查。这可能会导致远程存储库丢失提交;小心使用。
如果其他人已经删除了你的repo,那么如果不使用新的GitHub主分支替换自己的主分支(或者处理大量合并),他们就无法删除新的主历史记录。对于公共回购而言,除了git push,还有其他选择。Jefromi的答案(将正确的更改合并回原始主控形状)就是其中之一。
编辑:你没说你已经推到了公开回购!这是天壤之别。
有两种方式,“脏”的方式和“干净”的方式。假设您的分支名为new master。这是一种干净的方式:
git checkout new-master
git branch -m master old-master
git branch -m new-master master
# And don't do this part. Just don't. But if you want to...
# git branch -d --force old-master
这将使配置文件更改以匹配重命名的分支。
你也可以用脏的方式来做,这不会更新配置文件。这是在上面的罩下发生的事情。。。
mv -i .git/refs/new-master .git/refs/master
git checkout master
我在博客文章中找到了我想要的答案。用git中的另一个分支替换主分支:
git checkout feature_branch
git merge -s ours --no-commit master
git commit # Add a message regarding the replacement that you just did
git checkout master
git merge feature_branch
这与卡斯卡贝尔的答案基本相同。除了他们的解决方案下面的“选项”已经嵌入到上面的代码块中。
这样更容易找到。
我将此添加为新答案,因为如果以后需要此解决方案,我希望在一个代码块中包含所有需要使用的代码。
否则,我可能会复制并粘贴,然后阅读下面的详细信息,以查看我应该更改的行-在我已经执行它之后。
还可以将其他分支中的所有文件签出到master中:
git checkout master
git checkout better_branch -- .
然后提交所有更改。
只需访问gitlab或github网站,查找设置即可。
然后在设置下查找存储库。
在那里找到默认分支,展开它,您可以获得重命名它或将其更改为其他分支的选项。
我在gitlab尝试过,结果成功了。