准备工作
- 安装好XCode
- 配置好CocoaPods,并且可以pod update 以及 pod install 成功
- 已经获得CocoaPods的Repo的地址,以及对应pod的Git地址(这里以gitLab为例)
- 涉及到的所有操作,请尽量在Terminal中进行,包括CocoaPods的相关操作(CocoaPods官方客户端无效)
私有Spec Repo
所谓Spec Repo,就是Pods的索引。一旦在podfile中设置source为某个私有repo的git地址,在进行pod update的时候就会去这个repo中进行检索,如果检索到对应的pod,会读取该Pod的podspec从而进行安装。 一个Spec Repo的目录结构如下:
Spec Repo 目录
之后我们去GitLab上新建一个相应的Repo地址,之后添加repo到本地。
代码语言:javascript复制# pod repo add [Private Repo Name] [GitHub HTTPS clone URL]
pod repo add realTimeBusCocoaRepo https://gitlab.com/iosCocoaPods4CMS/iOS_Cocoapods_Repo.git
成功后可以进入~/.cocoapods/repos
目录下查看realTimeBusCocoaRepo
这个目录了。
创建Pod项目工程文件
这里建议通过CocoPods的官方命令来进行Pod项目的创建,以测试项目helloCMSPod为例,命令如下:
代码语言:javascript复制pod lib create helloCMSPod
不出意外地话,会提问你四个问题:
代码语言:javascript复制1.What language do you want to use?? [ Swift / ObjC ]
2.Would you like to include a demo application with your library? [ Yes / No ]
3.Which testing frameworks will you use? [ Specta / Kiwi / None ]
4.Would you like to do view based testing? [ Yes / No ]
5.What is your class prefix?
这里我分别选择了ObjC、Yes、None、Yes、CTDemo,之后会自动打开项目。 因为选择了View based testing,XCode8以上版本会检测到swift版本落后,邀请你升级,这时候可升可不升。 此时的目录树结构如下:
然后就是去新建好的项目里尽情的挥霍了:)
此时记得将所有更改放到Classes文件夹之下,然后在Example文件下执行 pod update,则可发现新的文件已经出现在项目工程的pods文件夹之下了。
之后要做的就是把库同步到Git上去了。这时候需要去GitLab上建立一个对应的仓库,例如:
代码语言:javascript复制https://gitlab.com/xxx.git (替换为自己的实际git地址)
然后将代码同步到此Git上。
代码语言:javascript复制git add .
git commit -m "Init"
git remote add origin https://gitlab.com/xxx.git(替换为自己的实际git地址)
git push --set-upstream origin master
podSpec文件需要版本控制信息,所以我们要打一个Tag.
代码语言:javascript复制git tag -m "first demo" 0.1.0
git push --tags
之后就可以去编辑podspec文件了。按以下方式来修改,不明白的字段请参考官方文档:
之后记得去在终端输入验证命令,确保该Podspec有效:
代码语言:javascript复制pod lib lint helloCMSPod.podspec
记得将更改好的podspec文件上传到git:
代码语言:javascript复制git add -A
git commit -m "change for podSpec"
git push
git tag -m "podSpec Demo" 0.1.1
git push --tags
向Spec Repo提交podspec
提交命令:
代码语言:javascript复制pod repo push xxxRepo helloXXXPod.podspec
在经过三轮的用户校验之后,提交成功!这时候我们去~/.cocoapods/repos/xxxRepo
中查看,我们的的podspec已经在里面了!
此时通过pod search helloXXXPod
已经可以查到了!
如何使用
我们可以在想要使用的项目中的Podfile里加入如下代码:
代码语言:javascript复制pod ‘helloXXXPod’
即可。 当然,由于我们的是私有CocoaPods库,因此最好告诉系统这个库的source在哪里,因此在Podfile文件上部也请加上Spec Repo的git地址
代码语言:javascript复制source 'https://gitlab.com/xxx.git'
整个的Podfile文件看起来是这样的:
之后运行pod update
即可安装对应的Pods
如果出现:
代码语言:javascript复制[!] An unexpected version directory `Assets` was encountered for the `/Users/xxx/helloxxxPod` Pod in the `helloCMSPod` repository.
这个错误,请查看:
- podspec 是否未上传到服务器
- Podfile的source地址是否是Spec Repo的地址,而不是具体某一个Pod的地址。
验证
新建一个SigleView的Project,配置好podfile后进行安装Pod,编译好运行,显示如下图:
至此,一次Pod拆分完成。
Reference
- 使用Cocoapods创建私有podspec
- 无数的StackOverflow