iOS SDK制作上传Pods的repo公共库管理包含.fram

2018-08-21  本文已影响75人  shawnr

iOS SDK制作上传Pods的repo公共库管理

开发SDK,并且SDK依赖别的未发布至pod库,需要依赖其他未发布至pod的SDK和.a等等,比较麻烦,所以SDK开发最好全部自己撸代码。
网上查到的资料大部分不清楚,有的太老旧,
所以在这儿整理下,加入自己的东西希望能有所帮助。环境 Xcode9.4.1,pod 1.5.3(关系不大)

1. 发布pods的准备

  1. pod、github的账号,公司电脑的话可能还需要多.ssh账号的配置和管理,这些问题信息都有。

2. 创建工程

  1. 进入指定文件夹使用pod命令创建模板工程
pod lib create testSDK

What platform do you want to use?? [ iOS / macOS ]
>
What language do you want to use?? [ Swift / ObjC ]
>
等问题自己选择尽可以啦

命令行生成模板工程.png

2. pod工程的预览、.podspec文件的了解

对于发布pod工程来说最重要的是.podspec文件的配置,该文件是管理pod版本,和能使别人搜索到你的SDK的关键

  1. 工程的结构:


    工程目录结构.png

注意ReplaceMe.m文件,右键 Show in Finder,如果有Classes,assets文件夹拖入工程,否则创建Classes文件拖入工程


添加文件的target选择.png
  1. .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

  1. GitHub创建空仓库,license选None
git创建工程.png
  1. 提交本地创建的工程至仓库
git add .
git commit -m ""
git remote add origin https://github.com/xxx/xx.git
git push -u origin master

4. 配置.podspec文件


一、如果你准备pod的工程只是.h、.m以及一些图片资源的话。在ReplaceMe.m文件的位置,删除ReplaceMe.m文件,创建Classes,Resources文件夹,然后把用到的文件分别加入对应的文件夹

注意文件的结构是相对于SDK文件夹的

二、项目包含未发布至pod的第三方SDK、.a文件等的配置

要发布至pod的自己的.a或者.framework其实和依赖的未发布至pod的三方库处理方式相同

5. 验证.podspec文件

执行 pod lib lint

s.summary的错误,描述要修改下,git仓库地址链接错误,修改s.source = { :git => 'https://github.com/xxxx/xxxSDK.git', :tag => s.version.to_s }, 链接指向自己的SDK工程地址

6. 提交到自己的GitHub,并验证

git add .
git commit -m ""
git push origin master:master
git tag 1.0.0
git push origin 1.0.0
打tag.png
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 trunk push xxxSDK.podspec

成功的反馈:

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

上一篇 下一篇

猜你喜欢

热点阅读