如何删除 Mercurial 中应用于错误分支的一些提交,然后在正确的分支上重播它们?

发布于 2024-09-11 06:31:29 字数 151 浏览 5 评论 0原文

我的同事在错误的分支上的存储库上提交了两次。

采取这两个提交、删除它们然后将它们正确提交到正确的分支下的最有效方法是什么? (更改尚未推送)

我们理想地希望有一种方法可以从 TortoiseHG 内部执行此操作,但当然,如果命令行是最佳选择,我们将使用它。

My colleague has committed twice on his repository on the wrong branch.

What is the most effective way to take those two commits, get rid of them and then commit them correctly under the right branch? (the changes have not been pushed)

We'd ideally like a way to do this from within TortoiseHG but of course, we'll use the command-line if it is the best option.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

下雨或天晴 2024-09-18 06:31:30

Mercurial 队列 (mq) 扩展可以提供帮助。

给定如下所示的更改历史记录:

@  changeset:   3:9dc681b56325
|  summary:     file4
|
o  changeset:   2:6675b3f86aa7
|  summary:     file3
|
| o  changeset:   1:4a3209ed5b2f
|/   summary:     file2
|
o  changeset:   0:6ab45ac3bd6d
   summary:     file1

以下命令将文件“file4”变更集移动到另一个分支(“file2”头):

hg qimport -r 3     // convert revision 3 to a patch
hg qpop             // remove it
hg update 1         // switch to the other branch head
hg qpush            // push the change back
hg qfin -a          // convert the applied patch back to a changeset

结果:

@  changeset:   3:3faa754edb0b
|  summary:     file4
|
| o  changeset:   2:6675b3f86aa7
| |  summary:     file3
| |
o |  changeset:   1:4a3209ed5b2f
|/   summary:     file2
|
o  changeset:   0:6ab45ac3bd6d
   summary:     file1

请注意,修订版 3 的变更集哈希已更改,因为变更集具有不同的值现在为人父母。 TortoiseHg 的更高版本也支持 MQ 扩展。

The Mercurial Queues (mq) extension can help.

Given a change history that looks like this:

@  changeset:   3:9dc681b56325
|  summary:     file4
|
o  changeset:   2:6675b3f86aa7
|  summary:     file3
|
| o  changeset:   1:4a3209ed5b2f
|/   summary:     file2
|
o  changeset:   0:6ab45ac3bd6d
   summary:     file1

The following commands moves file 'file4' changeset onto the other branch (the 'file2' head):

hg qimport -r 3     // convert revision 3 to a patch
hg qpop             // remove it
hg update 1         // switch to the other branch head
hg qpush            // push the change back
hg qfin -a          // convert the applied patch back to a changeset

Resulting in:

@  changeset:   3:3faa754edb0b
|  summary:     file4
|
| o  changeset:   2:6675b3f86aa7
| |  summary:     file3
| |
o |  changeset:   1:4a3209ed5b2f
|/   summary:     file2
|
o  changeset:   0:6ab45ac3bd6d
   summary:     file1

Note that the changeset hash for rev 3 changed, due to the changeset having a different parent now. Later versions of TortoiseHg support the MQ extension as well.

如果没有你 2024-09-18 06:31:30

据我所知,移植是最好的扩展。它将变更集应用于您想要的任何其他修订。

http://mercurial.aragost.com/kick-start/tasks.html #transplanting-changes

我的问题的解决方案是更新到应该应用两个更改的分支,移植两个更改集,然后使用 mq 删除更改​​。所有这些都可以在 tortoisehg 中完成。

From what I have found out, transplant is the best extension to use. It applies a changset to any other revision you want it to.

http://mercurial.aragost.com/kick-start/tasks.html#transplanting-changes

The solution to my problem was to update to the branch where the two changes should have been applied, transplant the two changesets in and then use mq to strip the changes. All do-able within tortoisehg too.

同尘 2024-09-18 06:31:30

在这种情况下,最好使用 hg rebase。

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

In this case it is much better to use hg rebase.

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

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文