【转载】Git单文件多次提交的cherry-pick

转自https://blog.csdn.net/htxhtx123/article/details/103952199
曾几何时,你发现你做的项目经常有甲方爸爸需要xxx定制版

“一堆定制版,你让我们怎么维护。我们是有骨气的程序员,安能摧眉折腰事权贵。”

“这个项目据说有2000万”

“明天给你验收包”

于是你的仓库里面就充满了各式各样的定制版分支。从此一个新功能要和n多个分支。

那么问题来了
你的定制版分支custom中测出了一个bug,而这个bug你在master分支已经修改了.

但是这个修改涉及了好几个commit和mergeRequest。cherry-pick可能会引入一些不必要的修改。

如果这个bug只影响了你的某一个文件(假设为Sample.cs)那么我们可以用下面这个命令来解救

git rev-list [-num] --reverse master – Sample.cs | git cherry-pick --stdin

这个是一个管道命令,实际上执行了2条git命令

我们看第一条

git rev-list [-num] --reverse master – Sample.cs

他是说将Sample.cs在master上的相关提交,选取最近的(num)个提交,

| git cherry-pick --stdin

说的是从标准输入设备中读取上一条命名输出的git提交号,进行cherry-pick

这样所有需要的提交就cherry-pick过来了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值