首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何删除两个提交之间的所有提交而不进行交互重基

如何删除两个提交之间的所有提交而不进行交互重基
EN

Stack Overflow用户
提问于 2020-11-20 11:37:12
回答 2查看 144关注 0票数 2

我有一个基于分支B的分支master,我想将B重新定位到分支A上。

我的问题是分支A是基于master中比B更早的提交,所以当我尝试将B重新定位到A上时,它带来了master的所有提交历史,因为A是与A分离的。

通常,我会使用交互式重基来解决这个问题,并手动删除不必要的提交,但是在这种情况下,有太多的提交无法以这种方式处理。我想要的是一个命令,允许我在分支B中删除它与A的最后一个共同祖先和master的尖端之间的所有提交。

即。从分支B删除提交图中的2-5的命令。

代码语言:javascript
复制
* 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
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-11-20 14:56:03

这正是--onto选项用于rebase的那种情况:

代码语言:javascript
复制
git switch B
git rebase --onto A master

这将把B的提交写到A上,从Bmaster之间最新的普通提交的子节点开始。

票数 5
EN

Stack Overflow用户

发布于 2020-11-20 13:49:42

代码语言:javascript
复制
# 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。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64928771

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档