8

假设我有 3 个未推送的提交。现在我想更改第一次或第二次提交的提交消息(将它们更改为第三次很简单git commit --amend)。怎么做?

4

2 回答 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 回答