[英]Git squash commits with merged branch
我正在处理master
分支,并创建了一个fix
分支,该分支在完成工作后又合并回master:
C ---. | fix
/ \
A -- B -- D | master
通过git log我可以看到:
commit 1992d90ff860b7f965d1cf24a199e2575f7761a9
Merge: 3ef8294 d2d8796
Date: Fri May 30 13:07:02 2014 +0800
Merge branch 'fix' -- D
commit d2d8796bc12a85b9948eee8d63fcbbf3b89d4aeb
Date: Thu May 29 10:57:13 2014 +0800
C
commit 3ef8294ce739f5f7524084b0b604132e40cf5fd9
Date: Fri May 16 14:35:11 2014 +0800
B
commit bfc45852466de4c3dcedc0ea24d8506312004e40
Date: Fri May 16 10:31:39 2014 +0800
A
现在我想将C,D的提交压缩为一个提交:
A -- B -- E | master
通常我通过rebase来压缩提交:
git rebase -i commit_of_B
但是在这种情况下它不起作用,git抱怨道:
error: could not apply d2d8796... C
有什么办法吗?
好吧,刚刚找到了带有选项-m
cherry-pick
方法:
git checkout -b work
git reset --hard HEAD^
git cherry-pick -m 1 1992d90ff
现在分支就像:
A -- B -- D | master
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.