在Mercurial中将选定的修订从一个分支合并到另一个分支

时间:2010-04-02 16:43:32

标签: mercurial branch merge

是否可以在Mercurial中将一系列修订从一个分支合并到另一个分支?

e.g。

|r1
|r2
|r3
|\___
|    | r5
|    | r6
|    | r7
|    | ...
|    | r40
|r41  

如果我想合并修订版6& 7,但不是5,进入主分支 - 这可能吗?

这样的合并可能是微不足道的,例如,如果r5修改过的文件未在6& 6中修改过。 7(如果不需要,可以安全地忽略它的变化)

从分支A到分支B的多个选定修订范围怎么样?例如合并4-7,20-25和30-34?

(这不是一个真实的案例,只是一个例子。我试图理解hg是否具有我知道svn具有的这个修订范围合并功能)

2 个答案:

答案 0 :(得分:9)

查看移植扩展程序​​的mercurial,我认为它会完全符合您的要求。

https://www.mercurial-scm.org/wiki/TransplantExtension

答案 1 :(得分:7)

简单的答案是

这与Mercurial的精神背道而驰。

您的图表意味着6取决于5,因此提取6的任何内容都应该提取5,否则就没有任何意义。

在我看来,你的Mercurial错了。如果您的更改树是线性的,那么通常表示您使用Mercurial就像使用CVS或SVN一样。

您的更改树应该更像:

   4
  / \
 /| |\
/ | | \
5 7 23 \
| | |   25
6 8 24  |
        26

然后你可以从5开始或从23开始提取分支。

现在,错误是人,所以有一个名为export的“工具”,它允许你从一个变更集创建一个简单的差异文件。

在您的具体情况下,您将:

  • 将存储库克隆到r4
  • r6创建差异,从r7(导出)
  • 创建一个差异
  • 将两个(按顺序)应用于新克隆(导入)​​
  • 运行单元测试,直到通过
  • 提交
  • 拉入r41
  • 合并
  • 运行单元测试,直到通过
  • 提交

如果您愿意,您也可以去延伸路。操作变更集有几个有用的扩展。样本集:

在这里你可以克隆存储库(重要的是,总是在克隆上测试这些,以防万一),然后折叠你感兴趣的范围。然后你可以导出/导入它们。