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

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

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


当前回答

Use

git status 

检查发生了什么。

Then

git checkout master 
git merge --squash bugfix
git add (add which files you want or use wildcard command like ".")

Then

git commit -m "message"

现在是最后但不是最不重要的

git push -u origin master

这里的原点可以是您喜欢的其他远程。

其他回答

最终让我明白这一点的是一条评论:

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可以得到我想要的结果,只需提交一次即可合并整个功能分支。而且,我最多只需要做一次手动冲突解决。

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

对于Git

创建新功能

通过终端/外壳:

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

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

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

假设您的bug修复分支称为bugfix,并且您希望将其合并到master中:

git checkout master
git merge --squash bugfix
git commit

这将从错误修复分支获取所有提交,将它们压缩为一个提交,并将其与主分支合并。


说明:

git checkout master

切换到主分支。

git merge --squash bugfix

从错误修复分支获取所有提交,并将其与当前分支分组为1次提交。(没有出现合并提交;您可以在提交之前手动解决冲突)

git commit

从合并的更改创建单个提交。

省略-m参数可以在完成提交之前修改包含压缩提交中的每个消息的提交消息草稿。

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

转到合并分支: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负责*