在使用 Mercurial 移植大量变更集时更改提交消息

Posted

技术标签:

【中文标题】在使用 Mercurial 移植大量变更集时更改提交消息【英文标题】:Changing the commit message while grafting a large number of changesets using Mercurial 【发布时间】:2017-12-08 08:39:20 【问题描述】:

我需要将大量(数千个)小型变更集从分支 A 移植到分支 B - 但需要在此过程中更改提交消息。

消息更改需要大致如下所示:

"Ref XXX: Fixed foo and bar" -> "GRAFT: Ref YYY: Fixed foo and bar".

换句话说,我需要在前面加上“GRAFT:”并更改参考编号。如果我不能直接使用 Mercurial 进行这些替换,我可以提前创建新的提交消息,然后制作一个脚本以在其各自的移植期间应用每条新消息。令人高兴的是,Mercurial 允许在嫁接期间使用 -e 参数编辑提交消息:

https://www.mercurial-scm.org/repo/hg/help/graft

问题是这会为每个变更集弹出一个文本编辑器,让我手动进行更改。似乎没有办法以编程方式修改消息,或者只是在注释行提供全新的消息。考虑到操作的规模,每次都使用编辑器是不合理的。

我的最后一个选择是使用带有某种 AutoIt/Macro 脚本的文本编辑器,在正确的时间在适当的地方输入正确的内容 - 但坦率地说,我觉得需要诉诸于此的想法让我有点感觉生病了。

救我脱离这个丑陋的命运。

提前致谢。

【问题讨论】:

【参考方案1】:

一种可能的解决方法是指定使用 shell 脚本代替编辑器。例如:

#!/bin/sh
sed -e '1,1s/^/GRAFT: /' -i "$1"

我们利用-ised 将进行就地编辑这一事实。不要忘记使 shell 脚本可执行。然后就可以运行了

hg graft --config ui.editor=/path/to/prepend-graft.sh -e -r <revision>

其中/path/to/prepend-graft.sh 是上述shell 脚本的路径。

更改数字可能需要比 sed 脚本更复杂的代码,但会遵循相同的方法。

【讨论】:

以上是关于在使用 Mercurial 移植大量变更集时更改提交消息的主要内容,如果未能解决你的问题,请参考以下文章

如何检查TFS服务器上是否有新的更改?

Mercurial:删除单个非头部变更集

Mercurial更新没有要求合并和覆盖工作目录

使用mercurial克隆或拉到标记后如何获取标记变更集?

Mercurial:我如何找出我的工作副本和另一个副本之间的区别

提交后修复Mercurial存储库中的重命名