我目前正在使用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
其他回答
上面讨论的一个小宝石-感谢@Codest和@Kevin Pullin。 在TortoiseHg中,在提交按钮旁边有一个下拉选项。选择“修正当前修订”会带回注释和文件列表。所以有用。
好消息:hg 2.2刚刚增加了git的修改选项。
在tortoiseHg中,你可以通过选择提交按钮右侧的黑色箭头来使用“修改当前修订”
我是这样做的。首先,不要强迫你的改变,否则你就不走运了。抓取并安装崩溃扩展。提交另一个虚拟变更集。然后使用折叠将前两个更改集合并为一个。它将提示您输入一条新的提交消息,为您提供您已经拥有的作为起点的消息。您已经有效地更改了原来的提交消息。
如果我想编辑的版本不是那么旧,我会使用一个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
回滚-重新应用是一个非常简单的解决方案,但它只对最后一次提交有帮助。Mercurial Queues功能强大得多(注意,为了使用“hg q*”命令,您需要启用Mercurial Queues Extension)。
推荐文章
- 为什么我需要显式地推一个新分支?
- 没有。Git目录的Git克隆
- 在TortoiseHg储存密码
- Git与Mercurial仓库的互操作性
- “node_modules”文件夹应该包含在git存储库中吗
- 为什么要把Gradle Wrapper提交给VCS?
- 自定义SSH端口上的Git
- Hg:如何做一个像git的rebase
- Mercurial:我可以重命名分支吗?
- Git克隆/拉不断冻结在“存储密钥在缓存?”
- 如何使用Git向远程存储库进行初始推送?
- 从pull请求中删除一个修改过的文件
- 在Mercurial中是否有删除本地提交的方法?
- Mercurial:如何修改上次提交?
- 如何使用TortoiseHG进行分支