首页
找靠谱产品
找解决方案
找靠谱公司
找案例
找对的人
专家智库
悬赏任务
SAAS
ToB门户
了解全球最新的ToB事件
论坛
潜水/灌水快乐,沉淀知识,认识更多同行。
ToB圈子
加入IT圈,遇到更多同好之人。
微博
Follow
记录
Doing
博客
Blog
文库
业界最专业的IT文库,上传资料也可以赚钱
下载
分享
Share
排行榜
Ranklist
相册
Album
应用中心
qidao123.com技术社区-IT企服评测·应用市场
»
论坛
›
软件与程序人生
›
移动端开发
›
IOS
›
【Git进阶】基于文件(夹)拆分大PR
返回列表
发新帖
【Git进阶】基于文件(夹)拆分大PR
[复制链接]
发表于 2022-9-17 08:39:21
|
显示全部楼层
|
阅读模式
背景
前段时间为了迁移一个旧服务到新项目,由此产生了一个巨大的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
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
继续阅读请点击广告
本帖子中包含更多资源
您需要
登录
才可以下载或查看,没有账号?
立即注册
×
回复
使用道具
举报
返回列表
去皮卡多
+ 我要发帖
×
登录参与点评抽奖,加入IT实名职场社区
去登录
微信订阅号
微信服务号
微信客服(加群)
H5
小程序
快速回复
返回顶部
返回列表