最近在研究如何使用Cocoapods打包静态库的功能,前期花了一段时间趟坑,现在有空正好总结下,给有需要的人!
一、如何使用Cocoapods打包Framework
1、首先保证自己已经正确安装CocoaPods环境,然后在git网站下载CocoaPods 打包插件,链接如下如下:
2、创建项目的问题在此不再赘述,前面有篇帖子讲过怎么使用命令创建的,在外面建好项目后随便新增几个类,保证能成功building不报错。然后我们打开项目中的podspec文件,修改git的source源为你要上传项目的本地路径,如箭头所指:
Source源然后对项目中依赖的第三方库、静态库、引入的公共头文件等进行配置,系统本身用到的framework是无法打进去的,但我这里还是填写了,目的是希望在之后测试项目中添加系统库的时候有名称依旧,省的漏掉。(别人用到你的静态库时还需把你项目中用到的系统库都在Link Binary With Libraries中补全,否则即使打包成功,但用起来还是会有很多报错)
配置示例如下:
相关配置3、打开终端,cd到podspec 文件所在目录路径下,需要把源码和版本号提交上去,具体规则如下:
git add . (添加库到git)
git commit -m “替换成自己的版本号” (根据实际的podspec版本)
git tag -a 替换成自己的版本号 -m “替换成自己的版本号” (给提交的版本打版本号,运行这句之后修改podspec 文件版本号与提交版本一致)
pod package XJSDK.podspec --force --embedded --no-mangle --exclude-deps
(打release 的包framework,如果在后面加上参数“--library”则打包成.a文件,--force是指强制覆盖)
pod package XJSDK.podspec --force --embedded --no-mangle --exclude-deps --configuration=DEBUG (打debug包,但其实release包也可以用来调试,不过好像不支持DEBUG模式下的宏定义代码)
以上两句pod package命令二选一即可,后面那句我也比较少用,只是尝试出来可以通过命令配置
4、执行完上面的步骤后进入等待,如果遇到报错,在终端搜索"error:"寻找错误来源。虽然有一大片错误代码,但是有些是具有误导性的,关键看最后那个文件和搜索到的错误提示,根据提示找到相关文件看是否有疏漏,实在看不懂就去百度吧!
我之前打包的这个项目因为模块之间项目嵌套引用太多,所以也是摸索了很久,解决不少bug才打出来。总结一下错误类型有如下几种:
第一种,就是头文件引入错误,导致文件无法找到等问题,把<>换成""。
第二种,断言导致打包失败,需要把所有的断言注释。
第三种,宏定义的问题,有些宏定义是在DEBUG模式下才生效的,如果刚好这下宏定义来自外部文件,有可能也会导致打包验证不通过,解决办法就是去掉这下DEBUG代码,或者迁移到你用到的文件。
第四种,就是podspec文件配置问题,路径不对、关键字写错等。
第五种,重复定义类文件,因为之前是不同模块的本地引入,而且多人开发,难免有些文件是重复了,如果路径刚好又很深,确实难以发现,只有看到错误提示后去搜索才能发现,解决办法就是删除掉另外一个。
5、若成功打包,则在项目路径下可以看到多出一个文件夹,打开进入则可以看到生成好的framework文件。
打包成功生成的文件6、另外就是打包项目中的plist和png文件都需要另外打一个bundle包提供给第三方用,具体打包方法请百度。
二、使用的注意事项
1、在提供本身打包成功的framework同时,还需把打包项目中用到的的.a和.framework文件提供给测试项目一起添加,并且在Taget设置中需要引入的系统库,前面我已经有提到。
原打包库中的静态库和资源文件 用到的系统库2、如果项目中刚好又用到swift的第三方库,那就在podfile文件添加“use_frameworks!”代码,系统会自动将pod的模块当做framework使用。
网友评论