我有一个基于分支B的分支master,我想将B重新定位到分支A上。
我的问题是分支A是基于master中比B更早的提交,所以当我尝试将B重新定位到A上时,它带来了master的所有提交历史,因为A是与A分离的。
通常,我会使用交互式重基来解决这个问题,并手动删除不必要的提交,但是在这种情况下,有太多的提交无法以这种方式处理。我想要的是一个命令,允许我在分支B中删除它与A的最后一个共同祖先和master的尖端之间的所有提交。
即。从分支B删除提交图中的2-5的命令。
* 099b4f7 (HEAD -> master) commit_6
| * a4b6a50 (B) some other commit
|/
* 80cfbbc commit_5
* 49c40c9 commit_4
* 2923714 commit_3
* f78ee3c commit_2
| * f6d3601 (A) some commit
|/
* df753e1 commit_1发布于 2020-11-20 14:56:03
这正是--onto选项用于rebase的那种情况:
git switch B
git rebase --onto A master这将把B的提交写到A上,从B和master之间最新的普通提交的子节点开始。
发布于 2020-11-20 13:49:42
# start from branch_B
git checkout branch_B
# back it up
git branch backup_B
# make it point to branch_A
git reset --hard branch_A
# bring all commits from branch_B not already on master
git cherry-pick master..backup_B它将给branch_A带来来自branch_B的每一个无法从获得的提交,所以它不会带来提交2、3和4。
https://stackoverflow.com/questions/64928771
复制相似问题