繁体   English   中英

在Mercurial中,有没有办法(除了“Cherry pick”之外)推动变更集而不推动与不同头部相关的变更集?

[英]In Mercurial, is there any way (aside from “Cherry picking”) to push a changeset without also pushing changesets associated with a different head?

这个问题的答案中, Ry4an声称“你不能在不推动Changeset1的情况下推动Changeset2”。

如果存储库看起来像这样,这当然有意义:

+ Changeset2
|
+ Changeset1
|
+ Original

然而,在以下场景中似乎没有那么多意义,这是我目前所拥有的:

+ Changeset2
|
|   + Changeset1
|  /
| /
+ Original

理想情况下,我希望能够将Changeset2推送回我最初克隆的存储库。 Mercurial似乎不愿意让我这样做。 它坚持我也推动Changeset 1 ......这是不允许的,因为它会在原始存储库中创建一个新头。 显然我可以“Cherry pick”,或者创建一个补丁来应用于原始存储库,但这看起来很笨拙。 我错过了什么吗?

更新:我可能在我最初的问题中提到我试图从TortoiseHg GUI执行操作。 作为Niall C. 在他的回答中正确地指出,Mercurial命令行允许我完成我所需要的,但是我仍然有兴趣学习是否有任何方法可以从GUI完成相同的操作。

如果你在没有任何命令行选项的情况下使用hg push ,它将尝试推送本地存储库中远程存储库中不存在的每个变更集。 如果使用-r / --rev选项,它将只推送该修订版及其祖先。 在您的情况下,您需要做:

hg push --rev Changeset2

有关详细信息,请参阅hg help push

对于喜欢图片的UI爱好者:

  1. 在TortoiseHg中,单击“ Detect outgoing changes to按钮。 在此输入图像描述

  2. 在要推送的修订版上单击鼠标右键。

  3. 选择Push -> Push to Here 在此输入图像描述

结果:您将仅推送选定的版本而不是所有内容。 在此输入图像描述

希望这能为您节省一些时间。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM