我正在使用Mercurial本地项目(这是唯一的回购,没有推/拉到/从其他任何地方)。

到目前为止,它有一个线性的历史。然而,我现在意识到我正在做的事情是一个糟糕的方法,我想回到我开始之前的版本,并以不同的方式实现它。

我对Mercurial中的分支/ revert / update -C命令有点困惑。基本上,我想要恢复到版本38(目前是45),并让我的下一次提交有38作为父,并从那里继续。我不在乎修订版39-45是否会永远消失,或者最终在他们自己的分支中陷入死胡同。

我需要哪个命令/一组命令?


当前回答

恕我直言,hg strip -r 39更适合这种情况。

它需要启用mq扩展,并具有与Martin Geisler推荐的“克隆回购方法”相同的限制: 如果变更集以某种方式发布,它(可能)会在某个时间点返回到您的回购,因为您只更改了本地回购。

其他回答

hg update [-r REV]

如果稍后提交,您将有效地创建一个新分支。然后您可以继续只在这个分支上工作,或者最终将现有的分支合并到它中。

我刚刚遇到了一个需要将一个文件恢复到以前版本的情况,就在我完成提交和推送之后。指定这些修订的简写语法没有包含在其他答案中,因此下面的命令可以做到这一点

hg revert path/to/file -r-2

-2将恢复到上次提交之前的版本,使用-1只会恢复当前未提交的更改。

我会安装Tortoise Hg (Mercurial的免费GUI)并使用它。然后,你只需右键单击你可能想要返回的版本——所有的提交消息都在你眼前——然后“恢复所有文件”。使在文件集的版本之间向后和向前滚动变得直观和容易,如果您希望确定问题第一次出现的时间,这可能非常有用。

上面的答案是最有用的,我学到了很多。然而,对于我的需求,简洁的回答是:

hg revert --all --rev ${1}

hg commit -m "Restoring branch ${1} as default"

其中${1}是修订的编号或分支的名称。这两行实际上是bash脚本的一部分,但是如果您想手动执行,它们本身就可以很好地工作。

如果您需要为发布分支添加一个热修复,但需要从默认值构建(直到我们获得正确的CI工具并能够从分支构建,然后再去掉发布分支),这是非常有用的。

恕我直言,hg strip -r 39更适合这种情况。

它需要启用mq扩展,并具有与Martin Geisler推荐的“克隆回购方法”相同的限制: 如果变更集以某种方式发布,它(可能)会在某个时间点返回到您的回购,因为您只更改了本地回购。