recursivemerge commits和squash merge commits不是一回事吗?这个问题与快进场景或合并操作完全无关。假设我们有一个名为“feature”的分支,其提交名为A,B和C。还有一个名为main的分支,其提交名为1和2,其中1实际上分支到特征分支。我们希望通过递归合并操作将这个“feature”分支合并到“main”分支上。作为递归合并操作的结果,一个新的合并提交将在主分支的末尾生成,它实现了由提交A、B和C所做的全部更改。这与压缩的合并提交有什么不同?更具体地说,是“--squash”参数?我、公司或工作流什么时候可能更喜欢压缩或递归合并提交?
2条答案
按热度按时间yhuiod9q1#
区别在于:
--squash
,OTOH,是关于如何处理合并结果的。特别是,它创建了一个没有第二个父提交的新提交。如果你省略了--squash
,则会创建一个合并提交(有两个父提交)。你所展示的例子,一个在提交的线性历史中演化的特性,不需要递归合并策略。当你有一个包含交叉合并的历史时,递归方面就开始起作用了。
在一个点上,一个半完成的特性被合并到
main
中(产生F
),在另一个点上,一个旧的main
状态,比如说,一个标记的版本,被合并到feature
中,产生R
。现在合并两个分支时,使用 * 递归 * 策略,因为两个分支有两个合并基,
r
和f
。合并通过合并r
和f
来构建虚拟树,然后将该树用作最终合并的合并基。可以将其视为线交叉的地方,x
.2ic8powd2#
这是两个不相关的正交设置。一个合并要么是递归的要么不是,要么是压缩的。所以你可以有
要明白的是:合并会创建一个新的提交。考虑到这个事实:
recursive
是关于创建提交的 * 逻辑 *。它修改了普通的合并逻辑;这不是一个你通常需要做的修改,如果你做了,你可能需要考虑更多的事情来得到一个“正确”的答案,所以我建议不要使用它。