cocoapods-ybin二进制源码映射使用教程
一、背景
随着项目业务的不断迭代和新增,每个业务线负责不同的功能模块,组件化势必是需要进行的工作。业界内,无论是哪种组件化方案,目的是一样的,分离业务和功能。
组件化虽好,但是组件化只是将不同的业务分离或者不同的功能分离和分层,实际上还是在一个代码池里每次 build 需要进行编译、汇编、链接等过程。每次编译的占用的时间还是挺奢侈的,在编译速度上并没有提升。pod install 来回切换二进制和源码也更是一件可行不可取的开发模式。
cocoapods-ybin 解决二进制和源码之间的映射问题,无需来回切换源码,实现二进制断点可进入源码进行调试。实现原理是简单的,但区别于 Android 里的 aar 或 jar 内的 Class 文件。
cocoapods-ybin 满足以下几个诉求考虑实现:
- 小而好用、低成本接入
- 与二进制库的制作和存储无关,只需二进制库和源码存储位置即可映射
- 同时支持多项目并行开发
- 只存储一份源码
- 无需频繁的 clone 代码
二、先睹为快
cocoapods-ybin-demo 示例效果视频,示例代码地址
三、安装
3.1 直接安装
1 | $ sudo gem install cocoapods-ybin |
3.2 使用 Gemfile 管理 pod 版本
添加 cocoapods-ybin 到 Gemfile 文件
1 | gem 'cocoapods-ybin' |
3.3 安装校验
执行命令 pod –help 查看当前 pod 版本 ybin 是否安装成功。
1 | $ pod --help |
四、使用教程
打开示例项目 ocoapods-ybin-demo 示例代码 的 Podfile 目录。示例项目使用了 Bundler 对 pod 的版本进行了控制,实际项目根据所需选择是否采用,与本插件无关联,请酌情选择。
4.1 执行二进制和源码映射指令
1 | $ pod ybin link 二进制库名称 |
4.2 查看已映射列表
1 | $ pod ybin link --list |
4.3 删除某个或多个源码映射
1 | $ pod ybin link --remove 二进制库名称1 二进制库名称2 |
4.4 删除所有源码映射
1 | $ pod ybin link --remove-all |
4.5 查询项目使用 Pod 管理的版本
查询项目通过Pod管理的组件库版本号,一般都是 cat Podfile.lock 文件,目视解析版本及依赖版本。阅读起来非常不友好,使用插件 –lib-version 扩展即可快速查看 Pod 管理的版本。
1 | $ pod ybin link --lib-version |
五、期待
- 如果在使用过程中遇到Bug,希望您能Issues我,谢谢(或者尝试下载使用最新版本看看Bug修复没有)
- 如果在使用过程中发现功能不够用,希望你能Issues我,非常想为这个工具增加更多好用的功能,谢谢
- 如果你想为cocoapods-ybin输出代码,请拼命Pull Requests我