概述
cocoapods 提供了一个打包插件:Cocoapods-package
- 第一步:安装 cocoapods-packager
sudo gem install cocoapods-packager
- 制作pod库demo
pod lib create DemoSDK
- 第三库打包静态库
pod lib lint Demo.podspec --allow-warnings --use-libraries --verbose 需要本地验证通过
pod spec lint Demo.podspec --allow-warnings --use-libraries --verbose 需要远程验证通过
pod package Demo.podspec --force --library --no-manglepo
- pod package 指令打包常用的指令集合
//强制覆盖之前已经生成过的二进制库
--force
//生成静态.framework
--embedded
//生成静态.a
--library
//生成动态.framework
--dynamic
//动态.framework是需要签名的,所以只有生成动态库的时候需要这个BundleId
--bundle-identifier
//不包含依赖的符号表,生成动态库的时候不能包含这个命令,动态库一定需要包含依赖的符号表。
--exclude-deps
//表示生成的库是debug还是release,默认是release。--configuration=Debug
--configuration
--no-mangle
//表示不使用name mangling技术,pod package默认是使用这个技术的。我们能在用pod package生成二进制库的时候会看到终端有输出Mangling symbols和Building mangled framework。表示使用了这个技术。
//如果你的pod库没有其他依赖的话,那么不使用这个命令也不会报错。但是如果有其他依赖,不使用--no-mangle这个命令的话,那么你在工程里使用生成的二进制库的时候就会报错:Undefined symbols for architecture x86_64。
--subspecs
//如果你的pod库有subspec,那么加上这个命名表示只给某个或几个subspec生成二进制库,--subspecs=subspec1,subspec2。生成的库的名字就是你podspec的名字,如果你想生成的库的名字跟subspec的名字一样,那么就需要修改podspec的名字。
这个脚本就是批量生成subspec的二进制库,每一个subspec的库名就是podspecName+subspecName。
--spec-sources
//一些依赖的source,如果你有依赖是来自于私有库的,那就需要加上那个私有库的source,默认是cocoapods的Specs仓库。--spec-sources=private,https://github.com/CocoaPods/Specs.git。 可以跟多个,多个逗号隔开
常见问题
问题一:
解决:
1、配置文件错误 source 路径不对。对应路径
2、私仓有些架构不支持 需要配置
#s.pod_target_xcconfig = { ‘VALID_ARCHS’ => ‘x86_64 armv7 arm64’ }
pod search 为什么搜索不到指定 SDK ?
执行 pod repo add 拉取 Pod 仓库到本地;
pod repo add AliyunRepo https://github.com/aliyun/aliyun-specs.git
问题1: xcode12及以上版本打包出现静态库arm64冲突问题
原因: xcode12苹果新增了模拟器的arm64架构和真机的arm64冲突了
修复方式: 用pod packets打包出错,在pod spec文件里忽略arm64 即可
#s.pod_target_xcconfig = { 'EXCLUDED_ARCHS[sdk=iphonesimulator*]' => 'arm64' }
最后
以上就是结实乐曲为你收集整理的cocoapods-packager打包静态库的全部内容,希望文章能够帮你解决cocoapods-packager打包静态库所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复