纸上得来终觉浅,绝知此事要躬行。

0%

cherry-pick一次merge的commit

cherry-pick 一次merge的提交提示:

1
Commit 140657867ed34483b9ce44959b8ae4c6a7b329b6 is a merge but no -m option was given.

原因:如果原始提交是一个合并节点,来自于两个分支的合并,那么 Cherry pick 默认将失败,因为它不知道应该采用哪个分支的代码变动。

-m配置项告诉 Git,应该采用哪个分支的变动。它的参数parent-number是一个从1开始的整数,代表原始提交的父分支编号。

1
-m parent-number--mainline parent-number
1
$ git cherry-pick -m 1 <commitHash>

上面命令表示,Cherry pick 采用提交commitHash来自编号1的父分支的变动。

一般来说,2号父分支是接受变动的分支(the branch being merged into),1号父分支是作为变动来源的分支(the branch being merged from)。