0.前言
现在越来越多的项目开始考虑组件化开发了,因此使得cocoapod搭建私有库成为一个必备的首要的技能。如同很多技术一样,搭建环境是最烦人的一步,相信很多人都会死在第一步搭建环境上。笔者我也是看着各种资料琢磨了半个多月终于搭起来的。看资料的过程是很烦人的,因为好多文章都是东拼西凑,感觉写文章的人都没有实际运行他写的步骤,特别让人讨厌。因此我搭建的必须是亲自一步步实践过的。应该不让您失望。
1.简单介绍几个概念
三方库的目录表specs:终端输入cd ~/.cocoapods/repos/master
可看到里面放的都是一个个的podspec文件大小仅仅为几KB,是三方库的索引文件。
私有库目录表的远程仓库:是目录表文件的远程存放地址。
私有库的远程仓库:这是我们自己写的想作为一个组件的代码。
行了就这三个概念,简单吧。
2.开始上具体组件代码
- 2.1 首先创建两个远程仓库
这个AutoziBaseSpec仓库只存放索引文件,占用很小就几kb。
这个AutoziBase仓库存放的代码
- 2.2 把要写具体代码的仓库拷下来,写入具体的组件代码
把实际代码仓库clone下来
cd Desktop/
git clone https://git.oschina.net/heeween/AutoziBase.git
- 2.3 我这里直接拷贝了我的一些base文件和分类文件
- 2.4 创建pod描述文件,让组件代码具有被cocoapod管理的能力
cd /Users/heew/Desktop/AutoziBase
pod spec create AutoziBase
这个时候会在桌面的项目文件中多了一个podspec文件
- 2.5 编辑podspec描述文件,主要就是讲清楚你这个私有库的地址和依赖关系等,下面是必须修改才能通过的地方
s.platform = :ios, "9.0"
s.source = { :git => "https://git.oschina.net/heeween/AutoziBase.git", :tag => "#{s.version}" }
s.source_files = "Base", "Category"
s.dependency 'Alamofire', '~> 4.0.1'
s.dependency 'SnapKit', '~> 3.0.2'
s.dependency 'SVProgressHUD', '~> 2.0.3'
s.dependency 'SwiftyJSON', '~> 3.1.1'
s.dependency 'Kingfisher', '~> 3.2.0'
我这里的组件化Base和Category里的代码依赖了5个知名的三方库,而alamofire在swift3.0中必须要求项目版本最低9.0,因此有了上面的设置。
- 2.6 设置完了以后,在终端中验证下AutoziBase这个项目是否真的具有了被cocoapod管理的能力,注意要添加allow-warning才可以通过。
pod lib lint --verbose --allow-warnings
基本上设置了以前的几个必要选项,基本上也没其他关键设置了,所以应该就可以通过了。或者你也可以直接任意下载一个知名的第三方库,cd到库里,运行pod lib lint --verbose可以详细看看别人的代码具体是怎么通过验证的。
- 2.7 给组件库打tag,并上传到git服务器,注意还是在AutoziBase代码的目录下执行一下命令
git add .
git commit -m "添加了base和category代码"
git tag -a 0.0.1 -m "添加0.0.1tag"
git push origin --tags
git push
所有以上操作全是在操作组件化代码,操作的目录也都是在AutoziBase这个项目的目录下。接着开始整项目索引文件
3.开始着手项目的索引文件
- 3.1把远程spec复制到本地pod管理目录文件夹中
pod repo add AutoziBaseSpec https://git.oschina.net/heeween/AutoziBaseSpec.git
cd ~/.cocoapods/repos/
open .
这时系统中.cocoapod的本地文件夹就出现了我们自己的项目索引文件AutoziBaseSpec文件
- 3.2一句代码添加刚才验证好的podsec到本地这个文件夹并且上传到远程目录管理服务器
注意这个时候必须回到AutoziBase这个具体项目的目录下来执行
cd /Users/heew/Desktop/AutoziBase
pod repo push AutoziBaseSpec AutoziBase.podspec --verbose --allow-warnings
- 必须回到AutoziBase具体项目的目录下
- 虽然是git上传但口令是pod repo push,不是git push
- AutoziBaseSpec写的是项目索引的名称,不是项目名称
- AutoziBase.podspec 是具体项目的描述文件podspec,就是刚才验证通过的文件
- 要加--allow-warnings 因为我们的描述文件有些不规范的地方
现在再看看项目描述远程仓库的样子
到现在所有配置就结束了
4.怎么使用
- 4.1创建一个demo项目来用用吧
xcode创建一个demo名称的工程,退出
cd /Users/heew/Desktop/demo
pod init
pod search AutoziBase
-
4.2搜索自己的私有库
终端中搜索到自己的私有库,这一步就很有成就感了,看图
这时编辑demo项目中多出的podfile文件,如下
- 4.3 编辑podfile
特别注意要添加两个源,并且使用use_frameworks
source 'https://github.com/CocoaPods/Specs.git'
source 'https://git.oschina.net/heeween/AutoziBaseSpec.git'
target 'demo' do
use_frameworks!
pod 'AutoziBase', '~> 0.0.1'
end
- 4.4最后的安装组件
终于到最后一步安装了
pod install