用Carthage编译你喜欢的静态库

前言
Carthage的基本用法已经在上一篇文章详细介绍了,本文主要针对一个问题的解决方案,那就是如何用Carthage编译第三方库为静态库。和pod package一样,封装了xcodebuild进行编译,省去了繁琐的参数设置,提供更便捷方法使用,Carthage作为后起之秀,维护力度和pod package相比,不是一个量级的,端午花了一天学习了下官方的文档,可以确定Carthage将会是第三方库打包成动态库或者静态库的首选。由于项目都还是Objective-C为主,因此我们不会全方位接入,而是使用它的打包功能,得力于他的松耦合,无侵入,可以配合Cocoapods结合使用,贼好用。
问题
Carthage默认只能编译成动态库。
解决方案
- Carthage 0.29.0以下
staticFramework脚本起了一个临时文件xcconfig,写入如下信息进行静态库的编译参数设置
LD = the/path/to/ld.py
EDBUG_INFOMATION_FORMAT = dwarf
该方法是老版本制作静态库的方法, 但是在Xcode 9.4之后,原生已经支持了Swift源码的静态库,我们只需要修改对应的mach-o type即可。
- Carthage 0.30.0之后
当前版本以及到最新的版本,都已经支持了OC和Swift的静态库,即使是已经支持了,但是如果你自己做一个库,要支持Carthage,默认的mach-o类型还是要是动态库类型,那么和之前的第三方库的制作和动态库基本没有任何区别。
- 库工程的project要支持shared schemes,
Product > Schemes > Manage Schemes > Shared - 使用的时候和动态库一样都需要手动拖入
Build phase中的Linked Binary,咱们等下用local pod来做,都不需要手动拖
那么步骤如下:
- 当我们
check out对应的库源码后,找到对应project下面的target,Build Settings,Linking section把Mach-O Type改为Static Library - 执行
carthage build --no-use-binaries --platfor ios,就可以在./Carthage/Build/$(PLATFORM_NAME)/Static下面生成对应的静态库 - 默认的动态库我们需要添加脚本
carthage copy-frameworks

最低0.47元/天 解锁文章
1827





