iOS SDK制作上传Pods的repo公共库管理
开发SDK,并且SDK依赖别的未发布至pod库,需要依赖其他未发布至pod的SDK和.a等等,比较麻烦,所以SDK开发最好全部自己撸代码。
网上查到的资料大部分不清楚,有的太老旧,
所以在这儿整理下,加入自己的东西希望能有所帮助。环境 Xcode9.4.1,pod 1.5.3(关系不大)
1. 发布pods的准备
- pod、github的账号,公司电脑的话可能还需要多.ssh账号的配置和管理,这些问题信息都有。
2. 创建工程
- 进入指定文件夹使用pod命令创建模板工程
pod lib create testSDK
- 命令运行后会有一些配置项的选择如:
命令行生成模板工程.pngWhat platform do you want to use?? [ iOS / macOS ]
>
What language do you want to use?? [ Swift / ObjC ]
>
等问题自己选择尽可以啦
2. pod工程的预览、.podspec文件的了解
对于发布pod工程来说最重要的是.podspec文件的配置,该文件是管理pod版本,和能使别人搜索到你的SDK的关键
-
工程的结构:
工程目录结构.png
注意ReplaceMe.m文件,右键 Show in Finder,如果有Classes,assets文件夹拖入工程,否则创建Classes文件拖入工程
添加文件的target选择.png
- .podspec文件的说明:
s.name 是项目的名字
s.version 是项目的版本控制,必须和tag一致(稍后提到)控制SDK的下载
s.summary 项目的概要,最好修改下,否则pod验证时可能报错
s.description 项目的描述,是概要的扩展,但是结构不可变,只能在TODO那一行增加东西,否则报错
s.homepage 项目主页,必须为可以链接到的页面,能打开就行
s.license 为协议,模板创建的不用改动
s.author 不用改动
s.source 这个也很关键,因为现在未提交至git库,所以没有链接,等提交后必须改动
s.ios.deployment_target iOS开发的依赖版本
s.source_files 为SDK库文件,打包SDK需要的.h、.m文件都在这里配置,稍后详细配置
s.frameworks 所需依赖的系统库文件,只能是系统库,如:s.frameworks = 'AVFoundation', 'CoreMotion', 'CoreMedia'
s.dependency 依赖的已经发布至pod库的第三方依赖,必须是已发布的,如:s.dependency 'AFNetworking'
s.resources .bundle、.png文件等
s.vendored_libraries 所需依赖的第三方库,未发布至pod仓库可以用此依赖,必须为.a的库
s.vendored_frameworks 所需依赖的第三方库,未发布至pod仓库,为.framework库
3. Github创建工程、并提交创建的工程至GitHub
- GitHub创建空仓库,license选None
- 提交本地创建的工程至仓库
git add .
git commit -m ""
git remote add origin https://github.com/xxx/xx.git
git push -u origin master
4. 配置.podspec文件
- s.homepage默认的配置在浏览器中打不开所以选择git项目的链接 s.homepage = "https://github.com/xxx/xxxSDK"
- s.source 项目已经提交到GitHub所以可以更改,一定腰围项目的git地址 s.source = { :git => 'https://github.com/edspayLei/XGCreditSDK.git', :tag => s.version.to_s }
- s.summary 也必须修改
- 接下来就要根据自己的项目进行特殊的配置啦。这里分情况介绍
一、如果你准备pod的工程只是.h、.m以及一些图片资源的话。在ReplaceMe.m文件的位置,删除ReplaceMe.m文件,创建Classes,Resources文件夹,然后把用到的文件分别加入对应的文件夹
- s.source_files = 'Classes/**/*.{h,m}'等,*是通配符,保证Classes 下的所有子文件中的.h、.m都能加载
- s.resources = 'Resources/*.png'
- s.dependency没有带s所以需要一个个的引用,还没有查复数的形式 s.dependency 'AFNetworking', '~> 3.2.1' s.dependency 'Masonry', '~> 1.1.0'
注意文件的结构是相对于SDK文件夹的
二、项目包含未发布至pod的第三方SDK、.a文件等的配置
- s.vendored_libraries中加入依赖的和自己要发布的.a文件
s.vendored_libraries = 'Classes/xxxSDK.a','Classes/xxxV2.2.1.a' - s.vendored_frameworks中加入依赖的和自己要发布的.framework文件:
s.vendored_frameworks = 'Classes/xxx.framework', 'Classes/myself.framework' - .a库的特殊处理,因为s.vendored_libraries中引入的.a文件并不包含.a需要暴露出来的文件,所以需要在s.source_files中把要暴露的文件引用,注意相对目录,有图片资源的话处理方式相同
要发布至pod的自己的.a或者.framework其实和依赖的未发布至pod的三方库处理方式相同
5. 验证.podspec文件
- 进入.podspec 所在的目录
执行 pod lib lint
-
错误处理
pod lib lint 错误.png
s.summary的错误,描述要修改下,git仓库地址链接错误,修改s.source = { :git => 'https://github.com/xxxx/xxxSDK.git', :tag => s.version.to_s }, 链接指向自己的SDK工程地址
- 验证成功,几乎已经完成了,恭喜
6. 提交到自己的GitHub,并验证
- 首先确定版本,这里我的版本从'1.0.0'开始,修改s.version = '1.0.0'
- 然后提交至自己的仓库
git add .
git commit -m ""
git push origin master:master
- 打tag 一定要和s.version = '1.0.0'相同,所以这里我们的tag为1.0.0
git tag 1.0.0
git push origin 1.0.0
打tag.png
- spec验证
pod spec lint xxxSDK.podspec
git URL错误的log.png
错误处理
分析是s.source 的问题,看链接是否为github的工程链接,修改
改完之后重新提交github,这样我们的tag1.0.0就不行了,所以需要重新打tag,我们选用tag为@"1.1.0",重新开始提交到pod的步骤。
验证通过的反馈:
![最后成功.png](https://img.haomeiwen.com/i1798452/4faf3c4af2c60edd.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
7. 提交.podspec文件至pod库
- 以上步骤都正确后,可以进行pod库的提交
pod trunk push xxxSDK.podspec
成功的反馈:
- .podspec推送至pod库,提交成功之后的搜索
pod search xxxSDK
错误 [!] Unable to find a pod with name, author, summary, or descriptionmatching `LPodTest
错误处理
pod库需要更新.png
1. pod setup (不行,实用方法二)
2. pod repo update(不行,试用方法三)
3. 前往这个路径下~/Library/Caches/CocoaPods删除search_index.json文件 , 或者使用终端命令删除:
```
rm -rf ~/Library/Caches/CocoaPods/search_index.json
```
然后重新搜索
删除本地pod索引库.png参考 ToSimple 参考链接 https://www.jianshu.com/p/41611b14942b
网友评论