我在本地存储库中有一堆主题相似的提交。我想把它们合并成一个单独的提交,然后再进行远程操作。我该怎么做?我认为rebase是这样做的,但我不明白这些文档。
当前回答
你可能想要使用交互式重基,在那个链接中有详细的描述。
如果你搜索“git rebase interactive”,你可以找到其他好的资源。
其他回答
如果你有很多提交,你只想压缩最后的X个提交,找到你想开始压缩的提交的提交ID
git rebase -i <that_commit_id>
然后按照豹的回答中所描述的那样进行,将所有的选择都改为压扁,除了第一个。
例子:
871adf OK, feature Z is fully implemented --- newer commit --┐
0c3317 Whoops, not yet... |
87871a I'm ready! |
643d0e Code cleanup |-- Join these into one
afb581 Fix this and that |
4e9baa Cool implementation |
d94e78 Prepare the workbench for feature Z -------------------┘
6394dc Feature Y --- older commit
你可以这样做(写提交的数量):
git rebase --interactive HEAD~[7]
或者这样(写你不想压缩的最后一个提交的哈希值):
git rebase --interactive 6394dc
你可能想要使用交互式重基,在那个链接中有详细的描述。
如果你搜索“git rebase interactive”,你可以找到其他好的资源。
你想要做的在git中被称为“挤压”。当你这样做的时候,有很多选择(太多了吗?),但如果你只是想将所有未推送的提交合并为一个提交,可以这样做:
git rebase -i origin/master
这将打开你的文本编辑器(-i是“交互式”),其中的文件如下所示:
pick 16b5fcc Code in, tests not passing
pick c964dea Getting closer
pick 06cf8ee Something changed
pick 396b4a3 Tests pass
pick 9be7fdb Better comments
pick 7dba9cb All done
改变所有的pick为squash(或s),除了第一个:
pick 16b5fcc Code in, tests not passing
squash c964dea Getting closer
squash 06cf8ee Something changed
squash 396b4a3 Tests pass
squash 9be7fdb Better comments
squash 7dba9cb All done
保存文件并退出编辑器。然后将打开另一个文本编辑器,让您将来自所有提交的提交消息组合成一个大的提交消息。
瞧!在谷歌上搜索“git squashing”,就会给出所有其他选项的解释。
您可以使用交互式Rebase压缩(加入)提交。YouTube上有一个非常棒的视频,展示了如何在命令行或SmartGit上做到这一点:
https://www.youtube.com/watch?v=qi_QAFrmHJM
如果你已经是一个SmartGit用户,那么你可以选择你所有的提交(按住Ctrl键),然后打开上下文菜单(右键单击)来压缩你的提交。
非常舒服:
Atlassian还有一个非常好的教程,展示了它是如何工作的:
https://www.atlassian.com/git/tutorials/rewriting-history/git-rebase-i
你可以使用git rebase -i,传入你想要用作“根”的修订:
git rebase -i origin/master
将打开一个编辑器窗口,显示在origin/master中最后一次提交之后所做的所有提交。您可以拒绝提交、将提交压缩为单个提交或编辑以前的提交。
有一些资源可能可以更好地解释这一点,并展示了一些其他的例子:
http://book.git-scm.com/4_interactive_rebasing.html
and
http://gitready.com/advanced/2009/02/10/squashing-commits-with-rebase.html
这是我能找到的头两页好书。
推荐文章
- GitHub -未能连接到GitHub 443 windows/连接到GitHub失败-无错误
- 如何使Eclipse/EGit在更新后识别现有的存储库信息?
- 撤销意外git隐藏pop
- 我怎么能让詹金斯CI与Git触发器推到主人?
- Git:哪个是分支的默认配置远程?
- 如何从拉请求中删除提交
- 如何用分发文件发布npm包?
- 跟踪在GitHub上创建的一个新的远程分支
- 没有空格的合并会产生冲突
- 如何使用refspec将Git标记推到分支?
- 如何使用Git向远程存储库进行初始推送?
- 将文件的当前工作副本与另一个分支提交的副本区别对待
- 配置Git接受特定https远程的特定自签名服务器证书
- 如何将一个特定的提交从一个分支合并到Git中的另一个分支?
- 通过SSH配置Git登录一次