假设我有 3 个未推送的提交。现在我想更改第一次或第二次提交的提交消息(将它们更改为第三次很简单git commit --amend
)。怎么做?
问问题
3237 次
2 回答
6
这是强大的git rebase -i
命令的工作。另外,请参阅 Git 书籍的交互式变基部分。
于 2010-10-15T07:31:41.453 回答
6
在子问题上反弹:是否有git commit --amend
前一个提交(而不仅仅是最后一个),您可以尝试类似(尚未测试,但Colin O'Dell在评论中提到为它编写了一个脚本colinodell /git-amend-old ):
git checkout -b tmp
git reset --hard HEAD~2
git commit -amend
git rebase --onto tmp HEAD@{1} master
那将是:
x---x---x---x---x
^
|
(master*) (* = current branch)
git checkout -b tmp
x---x---x---x---x
^
|
(tmp*, master)
git reset --hard HEAD~2
x---x---x---x---x
^ ^
| |
(tmp*) (master)
git commit -amend
y (tmp*)
/
x---x---x---x---x
| ^
(HEAD@{1}) |
(master)
git rebase --onto tmp HEAD@{1} master
(tmp)
y---x'---x' (master*)
/
x---x---x---x---x (only referenced in reflog)
于 2010-10-15T09:12:20.447 回答