git rebase
无需或 即可相当轻松地完成此操作 git merge --squash
。在此示例中,我们将压缩最后 3 个提交。
如果您想从头开始编写新的提交消息,这就足够了:
shellgit reset --soft HEAD~3 git commit
如果您想开始编辑新的提交消息与现有提交消息的串联(即类似于 pick/squash/squash/…/squash git rebase -i
指令列表将开始您的操作),那么您需要提取这些消息并通过他们 git commit
:
shellgit reset --soft HEAD~3 && git commit --edit -m"$(git log --format=%B --reverse HEAD..HEAD@{1})"
这两种方法都以相同的方式将最后三个提交压缩为一个新的提交。软重置只是将 HEAD 重新指向您不想压缩的最后一次提交。
软重置不会触及索引和工作树,从而使索引处于新提交所需的状态(即,它已经具有您要“丢弃”的提交的所有更改)。