赞
踩
有时候在一个分支的多次意义相近的 commit,会把整个提交历史搞得很混乱,此时可以将一部分的 commit 合并为一个 commit,以美化整个 commit 历史,可以使用 rebase 的方法来合并多次 commit,主要步骤如下:
比如需要将以下 3 个 ”请假应用客户端代码优化“ 的 commit 合并为一个 commit;
执行 git rebase -i HEAD~4 对最近的 4 个 commit 进行 rebase 操作;
具体的操作下面的 Commands 说明得很清楚了,对于 commit 合并可以使用 squash、fixup 指令,区别是 squash 会将该 commit 的注释添加到上一个 commit 注释中,fixup 是放弃当前 commit 的注释;
编辑后保存退出,git 会自动压缩提交历史,如果有冲突,记得解决冲突后,使用 git rebase --continue 重新回到当前的 git 压缩过程;
重新查看提交提交历史,会发现这些 commit 已经合并了,整个提交历史简洁了很多:
同样的,利用 git 压缩 rebase 指令来删除某个 commit,过程和以上是类似的;
在 git log 下,假如我们需要删除“请假应用客户端代码优化”这个 commit:
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。