论坛
潜水/灌水快乐,沉淀知识,认识更多同行。
ToB圈子
加入IT圈,遇到更多同好之人。
朋友圈
看朋友圈动态,了解ToB世界。
ToB门户
了解全球最新的ToB事件
博客
Blog
排行榜
Ranklist
文库
业界最专业的IT文库,上传资料也可以赚钱
下载
分享
Share
导读
Guide
相册
Album
记录
Doing
搜索
本版
文章
帖子
ToB圈子
用户
免费入驻
产品入驻
解决方案入驻
公司入驻
案例入驻
登录
·
注册
只需一步,快速开始
账号登录
立即注册
找回密码
用户名
Email
自动登录
找回密码
密码
登录
立即注册
首页
找靠谱产品
找解决方案
找靠谱公司
找案例
找对的人
专家智库
悬赏任务
圈子
SAAS
ToB企服应用市场:ToB评测及商务社交产业平台
»
论坛
›
软件与程序人生
›
移动端开发
›
IOS
›
【Git进阶】基于文件(夹)拆分大PR
【Git进阶】基于文件(夹)拆分大PR
去皮卡多
金牌会员
|
2022-9-17 08:39:21
|
显示全部楼层
|
阅读模式
楼主
主题
821
|
帖子
821
|
积分
2463
背景
前段时间为了迁移一个旧服务到新项目,由此产生了一个巨大的PR,为了方便Code Review,最终基于文件夹,将其拆分成了多个较小的PR;现在这里记录下,后面可能还会需要。
演示
为了方便演示,我创建了如下一个 large_pr_branch 到main的大PR,99+的文件修改
通过观察,我们可以将这个大PR,基于项目的分层结构,拆成5个较小的PR,即 NewApi、 Core 、 Infrastructure 、 UnitTest/IntegrationTest。
第一步 获取差分文件
首先通过 git diff 命令得到指定文件夹在large_pr_branch分支相较于main分支的差分文件(diff file),以 NewApi为例
git diff main large_pr_branch -- NewApi > newApi.diff
复制代码
newApi.diff文件已经生成,
打开可以看到它包含了NewApi文件夹下所有的修改
第二步 创建接收分支
接下来我们基于main分支创建一个新分支,用来后面接收newApi.diff
git checkout main
git checkout -b newapi_folder_branch
复制代码
第三步 应用差分文件
最后使用 git apply 命令将newApi.diff应用到新分支
git apply newApi.diff
复制代码
可以看到我们只将NewApi文件夹下的45个文件修改引入到新分支 newapi_folder_branch
后面的事就简单了,提交修改之后,我们只需要基于 newapi_folder_branch 分支创建PR到main分支,这样的得到PR,短小精悍,不会吓到同事^。
剩余文件夹重复上面的步骤即可。
如果你有更好的方式拆分大PR,欢迎评论区留言讨论^
参考链接
https://medium.com/@groksrc/protip-how-to-split-large-branches-into-small-pull-requests-81d607660c05
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
本帖子中包含更多资源
您需要
登录
才可以下载或查看,没有账号?
立即注册
x
回复
使用道具
举报
0 个回复
倒序浏览
返回列表
快速回复
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
or
立即注册
本版积分规则
发表回复
回帖并转播
回帖后跳转到最后一页
发新帖
回复
去皮卡多
金牌会员
这个人很懒什么都没写!
楼主热帖
民间最大社区,倒闭了!
FPGA虚拟化:突破次元壁的技术 ...
Ribbon负载均衡的深度分析和使用 ...
如何基于 ZEGO SDK 实现 iOS 变声/混响 ...
基于Kubernetes(k8s)部署Dubbo+Nacos服 ...
Git分支
驱动开发:内核R3与R0内存映射拷贝 ...
LyScript 实现应用层钩子扫描器 ...
聊聊简单又不简单的图上多跳过滤查询 ...
【必知必会的MySQL知识】⑤DQL语言 ...
标签云
挺好的
服务器
快速回复
返回顶部
返回列表