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