gpt4 book ai didi

git - 非线性 merge 后如何恢复线性git历史记录?

转载 作者:太空狗 更新时间:2023-10-29 13:11:30 24 4
gpt4 key购买 nike

很少提交之前我不小心在我的 master 分支中做了一个非线性 merge 。我有一个习惯,总是试图保持线性历史,所以现在我想恢复线性。

我制作了一个虚拟存储库,它模拟了我所拥有的真实情况,目的是使这更简单。这是它的 GitHub 链接:https://github.com/ruohola/merge-question

这是 git log --oneline --graph --date-order 的输出:

* 88a4b7e (HEAD -> master, origin/master, origin/HEAD) 11
* 5aae63c 10
* 5506f33 Merge branch 'other'
|\
| * b9c56c9 9
* | 3c72a2a 8
| * 8d2c1ea 7
| * 35f124b 6
* | 7ca5bc1 5
* | b9e9776 4
| * fd83f02 3
|/
* 4fa8b2e 2
* cbdcf50 1

Sourcetree 中的同一张图:

git log in sourcetree

这里是一个 mspaint 可视化,展示了我希望如何让我的 master 看起来像——它基本上应该像我在 merge 之前重新定位:
(哈希值会改变)

wanted end result

我知道这可能不是最佳实践,而且我熟悉重写历史的后果(虽然没有其他人在这个分支上工作),但仍然希望能够做到这一点。如何实现?

最佳答案

我认为这并不难,只要记住它需要重写 master 的历史:

git checkout b9c56c9
git rebase 3c72a2a # rebase on top of the other branch
git cherry-pick 5506f33..master # reapply changes from merge revision (dropping it) up until the tip of master
# if you like the results
git branch -f master
git checkout master

现在如果您已经在另一个远程拥有 master,您可以强制推送分支

关于git - 非线性 merge 后如何恢复线性git历史记录?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57328341/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com