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

2018-09-13 14:18:11 浏览数 (1)

准备工作

  • 安装好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

0 人点赞