我有一个远程Git服务器,下面是我要执行的场景:

对于每个bug/功能,我创建一个不同的Git分支我继续在Git分支中提交我的代码,并发送非官方Git消息在顶级存储库中,我们必须使用官方Git消息对一个bug进行一次提交

那么,我如何将我的分支合并到远程分支,以便他们对我的所有签入仅进行一次提交(我甚至想为此提供提交消息)?


当前回答

我知道这个问题不是专门针对Github的,但由于Github被广泛使用,这是我一直在寻找的答案,我将在这里分享。

Github能够执行压缩合并,这取决于为存储库启用的合并选项。

如果启用了挤压合并,“挤压并合并”选项将出现在“合并”按钮下的下拉列表中。

其他回答

使用自定义提交将newFeature分支合并到master中:

git merge --squash newFeature && git commit -m 'Your custom commit message';

如果相反,你会

git merge--压缩新功能和git提交

您将得到一条提交消息,其中包含所有newFeature分支提交,您可以自定义这些提交。

我在这里详细解释:https://youtu.be/FQNAIacelT4

假设您进行多次提交的分支的名称称为bugfix/123,并且您希望压缩这些提交。首先,从develop创建一个新分支(或者无论回购的名称是什么)。假设新分支的名称为bugfix/123_up。在gitbash中签出此分支-

git获取git checkout错误修复/123-upgitmerge错误修复/123--挤压gitcommit-m“您的消息”git推送原点错误修复/123-up

现在,该分支将只有一个提交,其中包含所有更改。

您的功能分支已完成并准备好只需一次提交即可提交到主分支、开发分支或其他目标分支

转到合并分支:git checkout master和git pull从干净的本地主机创建一个工作分支:gitcheckout-b workMerge在工作时挤压你的功能分支:git Merge--挤压你的_feature_branch。使用默认或新消息提交:gitcommit(使用特定或默认消息)返回功能分支:git checkout your_feature_branch将功能分支指向工作目录:git reset-hardwork验证,但您已准备好推送:git push-f如果需要,清理工作分支

用目标分支替换master:开发等等

无需指定从主节点到功能分支的提交次数。Git负责*

对于Git

创建新功能

通过终端/外壳:

git checkout origin/feature/<featurename>
git merge --squash origin/feature/<featurename>

这并不意味着你可以先回顾一下。

然后提交并完成这个新分支的功能,并删除/忽略旧分支(您开发的那个分支)。

git checkout YOUR_RELEASE_BRANCH
git pull
git checkout -b A_NEW_BRANCH
git merge --squash YOUR_BRANCH_WITH_MULTIPLE_COMMITS
git commit -am "squashing all commits into one"
git push --set-upstream origin A_NEW_BRANCH