首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在Mercurial中将选定修订从一个分支合并到另一个分支

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

Stack Overflow用户
提问于 2010-04-03 00:43:32
回答 2查看 2.9K关注 0票数 7

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

例如:

代码语言:javascript
复制
|r1
|r2
|r3
|\___
|    | r5
|    | r6
|    | r7
|    | ...
|    | r40
|r41  

如果我想将版本6和7合并到主分支中,而不是合并到主分支中,这可能吗?

这样的合并可能是微不足道的,例如,如果r5修改了在6&7中没有修改的文件(因此,如果不需要,可以安全地忽略它的更改)

从分支A到分支B的多个选定版本范围如何?例如,合并4-7,20-25和30-34?

(这不是一个真实的案例,只是一个例证。我想知道hg是否有我知道的svn的版本范围合并功能)

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2010-04-03 00:49:00

查看mercurial的移植扩展,我认为它会做你想要的事情。

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

票数 9
EN

Stack Overflow用户

发布于 2010-04-03 01:03:31

简单的答案是no

这与Mercurial的精神背道而驰。

您的图表明6依赖于5,所以任何拉动6的东西都应该拉动5,否则就没有意义了。

在我看来,您在这里搞错了Mercurial。如果您的更改树是线性的,则通常表明您正在使用Mercurial,就像使用CVS或SVN一样。

您的更改树应该看起来更像:

代码语言:javascript
复制
   4
  / \
 /| |\
/ | | \
5 7 23 \
| | |   25
6 8 24  |
        26

然后,您可以拉出从5开始的分支或从23开始的分支。

现在,错误是人为的,因此有一个名为export的“工具”,它允许您从一个变更集创建一个简单的diff文件。

在您的特定情况下,您可以这样做:

在新的克隆(导入)上,将存储库克隆到最高,一个与r6不同,一个从r7导入。在新的克隆(导入)上,

  • 运行您的单元测试,直到它们导入您的单元测试,直到它们被导入。

如果你愿意,你也可以走延伸路。有几个有用的扩展可用于操作变更集。一个样例集:

  • Rebase
  • Collapse

例如,您可以克隆存储库(重要的是,始终在克隆上测试它们,以防万一),然后折叠您感兴趣的范围。然后,您可以导出/导入它们。

票数 7
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2567876

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档