我想知道如何在两个旧提交之间插入一个新提交(提交X),但是(这是比较复杂的部分)我想在"分支点"之前插入(在本例中是提交"B")。
例如:
之前:
A -- B -- C <<< master
\
D -- E <<< branch
之后:
new commit
|
|
A -- X -- B -- C <<< master
\
D -- E <<< branch
我见过很多很好的答案,当这里没有分支时,它们非常有效:
- How to inject a commit between some two arbitrary commits in the past?
- https://blog.frankel.ch/inserting-new-commit-git-history/
但是当在分支点之前插入一个提交时,这些选项都不起作用,因为它们修改了树的"上游"部分。
解决这个问题的最好办法是什么?
对于上下文,我发现自己经常需要这样做的原因是,当我开始一个新的特性分支时,我意识到(在几次提交之后)一些改变应该更早地在主分支上完成,而不是在新特性分支上完成,例如,修改一些. vscode文件或更属于主分支而不是特性分支的代码的一些结构重构。
在这种情况下,这是"正确的做法"吗?
1条答案
按热度按时间ix0qys7i1#
这些都是普通的变基....在 old
B
中设置一个指针,这样运行第二次变基就更简单了。现在你有了一个名为
old-B
的分支,指向当前的B
:现在,取其中的任何一个配方,将
X
insertmaster
中,这样就得到了这个结果(通常是通过rebase或cherry-picks完成的):注意我是如何从图表中删除
branch
的......分支仍然存在,但现在整个图表 * 实际上 * 是这样的:请注意,您是如何拥有原始
B
和B'
的 * 克隆 * 的,克隆与原始并不完全相同,因为现在包括了X
的更改此时,你所要做的就是将
old-B..branch
范围内的提交放在B'
之上,这可以通过下面的rebase来实现:然后你会得到这个