3

我在 repo 中重命名了几个文件,并对它们进行了一些更改。现在,我只想提交我重命名文件的事实,然后分别提交更改。在 Mercurial 中这可能吗?

我看到的一种选择是搁置所有更改,然后手动记录所有重命名。我想知道是否有一种更自动化、更不容易出错的方式。

4

1 回答 1

3

Mercurial 没有内置的方法来执行此操作 - 提交将始终记录重命名和新文件内容。

但是,您可以通过几个步骤来完成。如果工作副本父级是 X,则执行以下操作:

  1. 提交混合的重命名和更改,称之为 Y

  2. 提取重命名并将其提交到 X,将此提交称为 Z

  3. 将 Y(混合提交)重新设置为 Z(仅重命名)。Rebase 足够聪明,可以看到 Y 中的重命名已经在 Z

在命令行上看起来像这样:

$ hg commit -m "mixed commit with both changes and renames"
$ hg update -r "p1(.)"
$ hg diff -c tip | grep "^\(diff\|rename\)" | hg import -m 'renames' -
$ hg rebase -s -2 -d .
于 2012-08-16T10:04:18.220 回答