总结
错误消息
没有之前的提交就不能“squash”
意味着你可能试图“向下挤压”。Git总是将一个新的提交压缩到一个旧的提交中,或者在交互的rebase todo列表中看到的“向上”,即压缩到前一行的提交中。将待办事项列表的第一行命令更改为“压缩”总是会产生这个错误,因为没有任何东西可以让第一个提交进行压缩。
修复
先回到你开始的地方
$ git rebase --abort
说你的历史
$ git log --pretty=oneline
a931ac7c808e2471b22b5bd20f0cad046b1c5d0d c
b76d157d507e819d7511132bdb5a80dd421d854f b
df239176e1a2ffac927d8b496ea00d5488481db5 a
也就是说,a是第一次提交,然后是b,最后是c。在提交c之后,我们决定将b和c合并在一起:
(注意:运行git日志将其输出输送到分页器,在大多数平台上默认情况较少。要退出寻呼机并返回命令提示符,请按q键。)
运行git rebase—interactive HEAD~2会给你一个编辑器
pick b76d157 b
pick a931ac7 c
# Rebase df23917..a931ac7 onto df23917
#
# Commands:
# p, pick = use commit
# r, reword = use commit, but edit the commit message
# e, edit = use commit, but stop for amending
# s, squash = use commit, but meld into previous commit
# f, fixup = like "squash", but discard this commit's log message
#
# If you remove a line here THAT COMMIT WILL BE LOST.
# However, if you remove everything, the rebase will be aborted.
#
(请注意,此todo列表与git log的输出顺序相反。)
将b的选择更改为squash将导致您看到的错误,但如果相反,通过将todo列表更改为将c压缩到b(新的提交到旧的或“向上压缩”)
pick b76d157 b
squash a931ac7 c
保存退出编辑器,你会得到另一个编辑器,它的内容是
# This is a combination of 2 commits.
# The first commit's message is:
b
# This is the 2nd commit message:
c
当你保存并退出时,编辑文件的内容将成为新的组合提交的提交消息:
$ git log --pretty=oneline
18fd73d3ce748f2a58d1b566c03dd9dafe0b6b4f b and c
df239176e1a2ffac927d8b496ea00d5488481db5 a
关于重写历史的说明
交互式rebase重写历史。试图推到包含旧历史记录的远程将失败,因为它不是快进。
如果你重基的分支是你自己工作的主题或特性分支,没有什么大不了的。推送到另一个存储库将需要——force选项,或者根据远程存储库的权限,您可以先删除旧的分支,然后再推送重新构建的版本。那些可能破坏工作的命令的示例超出了这个回答的范围。
在你和其他人一起工作的分支上重写已经发布的历史,而没有很好的理由,比如泄露密码或其他敏感细节,会迫使你的合作者承担工作,这是反社会的,会惹恼其他开发人员。git Rebase文档中的“从上游Rebase中恢复”部分解释了这一点,并增加了重点。
重基于(或任何其他形式的重写)其他人基于工作的分支是一个坏主意:下游的任何人都被迫手动修复他们的历史。本节将从下游的角度解释如何进行修复。然而,真正的解决办法是首先避免上游的基地改变。...