我目前正在使用TortoiseHg (Mercurial),不小心提交了一个错误的提交消息。如何在存储库中编辑这条提交消息?
当前回答
如果我想编辑的版本不是那么旧,我会使用一个hack:
假设你的转速是500,而你想编辑497。
hg export -o rev497 497
hg export -o rev498 498
hg export -o rev499 499
hg export -o rev500 500
编辑rev497文件并更改消息。(它位于以“#”开头的第一行之后)
hg import rev497
hg import rev498
hg import rev499
hg import rev500
其他回答
我知道这是一个老帖子,你把问题标记为答案。我正在寻找同样的事情最近,我发现histedit扩展非常有用。这个过程解释如下:
http://knowledgestockpile.blogspot.com/2010/12/changing-commit-message-of-revision-in.html
更新:Mercurial增加了-修正,现在应该是首选的选项。
您可以使用hg回滚回滚上一次提交(但只能是最后一次),然后重新应用它。
重要的是:这将永久地删除最新的提交(或拉取)。所以如果你做了hg更新,commit不再在你的工作目录中,那么它就永远消失了。所以先复制一份。
除此之外,您不能更改存储库的历史记录(包括提交消息),因为其中的所有内容都是校验和的。您唯一能做的就是在给定的变更集之后修剪历史记录,然后相应地重新创建它。
如果您已经发布了您的更改(除非您可以获得所有的副本),这些都将不起作用,并且您也不能“重写历史”,包括gpg签名提交(由其他人)。
好消息:hg 2.2刚刚增加了git的修改选项。
在tortoiseHg中,你可以通过选择提交按钮右侧的黑色箭头来使用“修改当前修订”
上面讨论的一个小宝石-感谢@Codest和@Kevin Pullin。 在TortoiseHg中,在提交按钮旁边有一个下拉选项。选择“修正当前修订”会带回注释和文件列表。所以有用。
编辑:正如用户指出的那样,不要使用MQ,而是使用提交—修改。这个答案现在大多具有历史意义。
正如其他人所提到的,MQ扩展更适合此任务,并且您不会冒破坏工作的风险。这样做:
启用MQ扩展,在hgrc中添加如下内容: (扩展) mq = 更新到您想要编辑的变更集,通常提示: Hg上升$rev 将当前的变更集导入队列: Hg qimport -r。 刷新补丁,编辑提交消息: Hg qrefresh -e 完成所有应用的补丁(在本例中是一个),并将它们存储为常规更改集: Hg qfinish a
我不熟悉TortoiseHg,但是命令应该与上面的类似。我还认为值得一提的是,编辑历史是有风险的;只有在您绝对确定更改集没有被推送到其他地方或从其他地方拉出时,才应该这样做。
推荐文章
- 在Mercurial中是否有删除本地提交的方法?
- Mercurial:如何修改上次提交?
- 如何使用TortoiseHG进行分支
- 如何从我的工作目录中删除所有未跟踪的文件?
- 多久向源代码控制提交一次更改?
- 如何修改旧Git提交?
- 如何处理11000行c++源文件?
- 删除git中的分支是否会将其从历史记录中删除?
- 如何做Mercurial的'hg删除'所有丢失的文件?
- "ERROR:root:code for hash md5 was not found"当使用任何hg mercurial命令时
- Mercurial初学者:最终实用指南
- 什么是跟踪分支?
- Git -合并时跳过特定的提交
- 为什么3路合并比2路合并更有利?
- 如何正确地关闭一个功能分支在Mercurial?