我有一个远程Git服务器,下面是我要执行的场景:
对于每个bug/功能,我创建一个不同的Git分支我继续在Git分支中提交我的代码,并发送非官方Git消息在顶级存储库中,我们必须使用官方Git消息对一个bug进行一次提交
那么,我如何将我的分支合并到远程分支,以便他们对我的所有签入仅进行一次提交(我甚至想为此提供提交消息)?
我有一个远程Git服务器,下面是我要执行的场景:
对于每个bug/功能,我创建一个不同的Git分支我继续在Git分支中提交我的代码,并发送非官方Git消息在顶级存储库中,我们必须使用官方Git消息对一个bug进行一次提交
那么,我如何将我的分支合并到远程分支,以便他们对我的所有签入仅进行一次提交(我甚至想为此提供提交消息)?
当前回答
假设您进行多次提交的分支的名称称为bugfix/123,并且您希望压缩这些提交。首先,从develop创建一个新分支(或者无论回购的名称是什么)。假设新分支的名称为bugfix/123_up。在gitbash中签出此分支-
git获取git checkout错误修复/123-upgitmerge错误修复/123--挤压gitcommit-m“您的消息”git推送原点错误修复/123-up
现在,该分支将只有一个提交,其中包含所有更改。
其他回答
假设您进行多次提交的分支的名称称为bugfix/123,并且您希望压缩这些提交。首先,从develop创建一个新分支(或者无论回购的名称是什么)。假设新分支的名称为bugfix/123_up。在gitbash中签出此分支-
git获取git checkout错误修复/123-upgitmerge错误修复/123--挤压gitcommit-m“您的消息”git推送原点错误修复/123-up
现在,该分支将只有一个提交,其中包含所有更改。
使用自定义提交将newFeature分支合并到master中:
git merge --squash newFeature && git commit -m 'Your custom commit message';
如果相反,你会
git merge--压缩新功能和git提交
您将得到一条提交消息,其中包含所有newFeature分支提交,您可以自定义这些提交。
我在这里详细解释:https://youtu.be/FQNAIacelT4
我知道这个问题不是专门针对Github的,但由于Github被广泛使用,这是我一直在寻找的答案,我将在这里分享。
Github能够执行压缩合并,这取决于为存储库启用的合并选项。
如果启用了挤压合并,“挤压并合并”选项将出现在“合并”按钮下的下拉列表中。
假设您在feature/task1中使用了多个提交。
转到项目分支(project/my_project)git签出项目/my_project创建新分支(feature/task1_bugfix)git checkout-b feature/task1_bugfix使用--squash选项合并git merge--挤压功能/task1创建单个提交gitcommit-am“添加单个注释”推你的树枝git push—设置上游原点功能/task1_bugfix
最终让我明白这一点的是一条评论:
git checkout main
git merge --squash feature
相当于:
git checkout feature
git diff main > feature.patch
git checkout main
patch -p1 < feature.patch
git add .
当我想将一个功能分支与105(!!)个提交合并并将它们全部压缩为一个时,我不想git rebase-I origin/master,因为我需要分别解决每个中间提交的合并冲突(或者至少是git自己无法解决的提交)。使用gitmerge--squash可以得到我想要的结果,只需提交一次即可合并整个功能分支。而且,我最多只需要做一次手动冲突解决。