前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Git单文件多次提交的cherry-pick

Git单文件多次提交的cherry-pick

作者头像
黄腾霄
发布2020-06-10 11:00:18
1.1K0
发布2020-06-10 11:00:18
举报
文章被收录于专栏:黄腾霄的博客

曾几何时,你发现你做的项目经常有甲方爸爸需要xxx定制版


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

“这个项目据说有2000万”

“明天给你验收包”

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

那么问题来了

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

但是这个修改涉及了好几个commitmergeRequest。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.csmaster上的相关提交,选取最近的(num)个提交,

| git cherry-pick --stdin

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

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


本文会经常更新,请阅读原文: https://xinyuehtx.github.io/post/Git%E5%8D%95%E6%96%87%E4%BB%B6%E5%A4%9A%E6%AC%A1%E6%8F%90%E4%BA%A4%E7%9A%84cherry-pick.html ,以避免陈旧错误知识的误导,同时有更好的阅读体验。

本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可。欢迎转载、使用、重新发布,但务必保留文章署名黄腾霄(包含链接: https://xinyuehtx.github.io ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。如有任何疑问,请 与我联系

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018-04-25 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 那么问题来了
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档