我在本地存储库中有一堆主题相似的提交。我想把它们合并成一个单独的提交,然后再进行远程操作。我该怎么做?我认为rebase是这样做的,但我不明白这些文档。
当前回答
我压缩多次推送的方法是(也许你向你自己的分支推送了很多提交,现在你想做一个pull请求,你不想用你已经推送的许多提交来混乱它们)。我这样做的方式(就我所知,没有其他更简单的选择)。
创建一个新的分支(你希望将请求拉到的原始分支)。 推送新创建的分支。 合并分支并提交(已经推送)到新分支。 重新建立新的分支和挤压。 推送新分支。 为新分支创建新的拉请求,该分支现在有单次提交。
例子:
git checkout from_branch_you_wish_to_pull_request_to
git checkout -b new_branch_will_have_single_squashed_commit
git push -u new_branch_will_have_single_squashed_commit
git merge older_branch_with_all_those_multiple_commits
git rebase -i (here you squash)
git push origin new_branch_will_have_single_squashed_commit
现在可以将请求拉入from_branch_you_wish_to_pull_request_to
其他回答
你可能想要使用交互式重基,在那个链接中有详细的描述。
如果你搜索“git rebase interactive”,你可以找到其他好的资源。
我压缩多次推送的方法是(也许你向你自己的分支推送了很多提交,现在你想做一个pull请求,你不想用你已经推送的许多提交来混乱它们)。我这样做的方式(就我所知,没有其他更简单的选择)。
创建一个新的分支(你希望将请求拉到的原始分支)。 推送新创建的分支。 合并分支并提交(已经推送)到新分支。 重新建立新的分支和挤压。 推送新分支。 为新分支创建新的拉请求,该分支现在有单次提交。
例子:
git checkout from_branch_you_wish_to_pull_request_to
git checkout -b new_branch_will_have_single_squashed_commit
git push -u new_branch_will_have_single_squashed_commit
git merge older_branch_with_all_those_multiple_commits
git rebase -i (here you squash)
git push origin new_branch_will_have_single_squashed_commit
现在可以将请求拉入from_branch_you_wish_to_pull_request_to
您可以使用交互式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
我想到了
#!/bin/sh
message=`git log --format=%B origin..HEAD | sort | uniq | grep -v '^$'`
git reset --soft origin
git commit -m "$message"
合并、排序、统一和删除提交消息中的空行。我使用这个对github维基进行本地更改(使用咕噜)
如果你有很多提交,你只想压缩最后的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配置存储为存储库的一部分?
- 如何修改GitHub拉请求?
- 如何在Github和本地删除最后n次提交?
- 我如何调试git/git-shell相关的问题?
- 错误:无法使用rebase进行拉取:您有未分阶段的更改
- Git隐藏未缓存:如何把所有未分期的变化?
- 真实的恶魔
- 如何从另一个分支获得更改
- Git:权限被拒绝(publickey)致命-无法从远程存储库读取。克隆Git存储库时
- git reflog和log有什么区别?
- git推挂在Total line之后
- 重命名git子模块
- 结合Git存储库的前两次提交?
- Xcode 6 gitignore文件应该包括什么?
- 我如何从现有回购的分支创建一个新的GitHub回购?