前言
我们经常使用podfile文件去拉取别人的framework,那有没有想过我们自己也做一个SDK上传到cocoapods呢?
1. 安装cocoapods
第一步肯定是本地先安装pod环境,不再细讲了,具体可参考:
https://www.jianshu.com/p/0f6e5a7dace5
2. 创建代码仓库
去GitHub创建一个自己的代码仓库,然后把你要上线的代码或者framework提交到这个仓库。然后本地和远端就都有了代码仓库。
注意framework路径,需要跟你podspec文件中对应。
3. 给pod打版本号
其实是给项目打一个tag,这样pod 就可以检索到具体的tag,一般都是版本号作为tag。
查看当前tag 列表信息:git tag -a
新增tag版本号:git tag -a "版本号"
推送tag到远端:git push --tags
(如果失败可以直接去GitHub打tag)
4. 创建podspec文件
podspec文件是cocoapods找到代码仓库的索引文件。
可以通过命令一键创建:pod spec create 名字
podspec文件的官方范本和说明: http://guides.cocoapods.org/making/specs-and-specs-repo.html
5. podspec文件检验
执行pod lib lint --allow-warnings 对文件进行校验
在校验文件时,可能会遇到校验不通过的问题,通过–verbose参数进行问题排查
修改完毕后,继续检查,如果出现警告warning,可以采用--allow-warnings 参数来允许警告
6. 注册trunk账号
pod trunk register 邮箱账号 'mobsdk' --verbos
查看本机trunk session注册命令:pod trunk me
这一步不报错即为验证通过。
7. 推送podspec到trunk
pod trunk push BaiduMobAdSDK.podspec --allow-warnings
如果出现失败,多试几次即可。
8. pod search *** 验收版本
pod search ***(pod名字)验收版本,或者通过trunk网站搜索pod名字查看:https://cocoapods.org/
pod search不到的话需要更新本地仓库,通过:pod repo update
9. 完事(其余问题看附录)
pod升级
1. 提交代码,打包,替换framework
2. 修改podspec文件中的版本号
3. 检查本地代码编译情况:pod lib lint --allow-warnings
4. ci代码push git仓库
5. 打版本tag:例如1.1
1. git tag -a "1.1"
2. git push --tags
6. 推送tag到trunk:pod trunk push *.podspec --allow-warnings
7. pod search * 验收版本
附录:podspec配置:
name:pod库名字
version:版本号,每次升级都需要改,切默认位数多的排在前面
summary:概述
homepage:代码仓库地址
license:开源协议,可以自行百度,通常写MIT
author:作者
source:源码git地址
platform:最低支持的ios版本
source_files:源文件(可以包含.h和.m)
public_header_files:对外公开的头文件(.h文件)
resources:资源文件
resource_bundles:资源文件,指定bundles
frameworks:依赖的系统框架多个之间逗号分割
vendored_frameworks:依赖的非系统框架,比如你自己的framework
libraries:依赖的系统库,如:C++
vendored_libraries:依赖的非系统的静态库
dependency:依赖的三方库
pod_target_xcconfig:支持的架构,如armv7
官方样例:系统创建的时候很多都给你注释写好了,注意看多测试就好
Pod::Spec.new do |spec|
spec.name = 'Reachability'
spec.version = '3.1.0'
spec.license = { :type => 'BSD' }
spec.homepage = 'https://github.com/tonymillion/Reachability'
spec.authors = { 'Tony Million' => 'tonymillion@gmail.com' }
spec.summary = 'ARC and GCD Compatible Reachability Class for iOS and macOS.'
spec.source = { :git => 'https://github.com/tonymillion/Reachability.git', :tag => 'v3.1.0' }
spec.source_files = 'Reachability.h,m'
spec.framework = 'SystemConfiguration'
spec.requires_arc = true
end