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)。