IOS 上线SDK到pod仓库

前言

我们经常使用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' => '[email protected]' }
  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

你可能感兴趣的:(IOS 上线SDK到pod仓库)