在我的存储库中,我有一个名为aq的分支,我正在处理它。
然后我在master中提交了新的工作和bug。
将这些提交到aq分支的最佳方法是什么?从master中创建另一个新分支,并将其与aq合并?
在我的存储库中,我有一个名为aq的分支,我正在处理它。
然后我在master中提交了新的工作和bug。
将这些提交到aq分支的最佳方法是什么?从master中创建另一个新分支,并将其与aq合并?
当前回答
场景:
我从master创建了一个分支,比如branch-1,并将其拉到我的本地。 我的朋友从master创建了一个分支,比如branch-2。 他向master提交了一些代码更改。 现在我想把这些更改从主分支转移到本地分支。
解决方案
git stash // to save all existing changes in local branch
git checkout master // Switch to master branch from branch-1
git pull // take changes from the master
git checkout branch-1 // switchback to your own branch
git rebase master // merge all the changes and move you git head forward
git stash apply // reapply all you saved changes
执行“git stash apply”后,您可以在文件中发现冲突。您需要手动修复它,现在您已经准备好执行了。
其他回答
您也可以通过运行一行来实现这一点。 Git合并aq master
这相当于
git checkout aq
git merge master
与aq合并
git checkout master
git pull
git checkout aq
git merge --no-ff master
git push
不能保证主错误修复不在其他提交中,因此不能简单地合并。做
git checkout aq
git cherry-pick commit1
git cherry-pick commit2
git cherry-pick commit3
...
假设这些提交代表bug修复。
但是从现在开始,将错误修复放在一个单独的分支中。你就可以
git merge hotfixes
当你想要将它们全部滚动到常规开发分支时。
这个(从这里)对我很有用:
git checkout aq
git pull origin master
...
git push
引用:
Git pull origin master获取并合并master的内容 分支和你的分支并创建一个合并提交。如果有的话 合并冲突将在此阶段通知您,您必须解决 在继续之前提交合并。当你准备好推你的 本地提交,包括新的合并提交,到远程服务器, 运行git push。
当你在aq分支上时,你应该能够git合并origin/master。
git checkout aq
git merge origin/master