iOS模块化实践 -- 利用CocoaPods拆分项目

2017-01-14 10:05:40来源:http://www.jianshu.com/p/a73b6bfdb41a作者:nimomeng人点击

准备工作
安装好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到本地。


# 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为例,命令如下:


pod lib create helloCMSPod

不出意外地话,会提问你四个问题:


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上建立一个对应的仓库,例如:


https://gitlab.com/xxx.git (替换为自己的实际git地址)

然后将代码同步到此Git上。


git add .
git commit -m "Init"
git remote add origin https://gitlab.com/xxx.git(替换为自己的实际git地址)
git push --set-upstream origin master

podSpec文件需要版本控制信息,所以我们要打一个Tag.


git tag -m "first demo" 0.1.0
git push --tags

之后就可以去编辑podspec文件了。按以下方式来修改,不明白的字段请参考官方文档:




之后记得去在终端输入验证命令,确保该Podspec有效:


pod lib lint helloCMSPod.podspec

记得将更改好的podspec文件上传到git:


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

提交命令:


pod repo push xxxRepo helloXXXPod.podspec

在经过三轮的用户校验之后,提交成功!这时候我们去~/.cocoapods/repos/xxxRepo中查看,我们的的podspec已经在里面了!


此时通过pod search helloXXXPod 已经可以查到了!




如何使用

我们可以在想要使用的项目中的Podfile里加入如下代码:


pod ‘helloXXXPod’
``
即可。
当然,由于我们的是私有CocoaPods库,因此最好告诉系统这个库的source在哪里,因此在Podfile文件上部也请加上Spec Repo的git地址

source 'https://gitlab.com/xxx.git'


整个的Podfile文件看起来是这样的:
![](http://upload-images.jianshu.io/upload_images/2340489-c9b30f5ee69ecdd1.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
之后运行```pod update``` 即可安装对应的Pods
如果出现:

[!] 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





最新文章

123

最新摄影

微信扫一扫

第七城市微信公众平台