目的:
构建自己的一个组件,放在公司的私有pod库中
然后可以通过cocoapod来导入这个pod库
在构建私有库之前,先了解以下几个基本基本...概念
repo(repository仓库)
repo只是google用Python脚本写的调用git的一个脚本,主要是用来下载、管理Android项目的软件仓库。
Pod(代码库)
分为
公有库:放在外网上,其他开发者是可以访问使用的
私有库:放在本地或者内网上,只有公司内部的人员可以使用
创建公有Pod库或者私有Pod库, 实际上原理是一样的, 都是基于git服务和repo协议,不一样的是, 两者的版本索引查询方式不一样, 公有库的podspec由CocoaPods/Specs管理, 而内部私有使用的pod库需要自己建立一个仓库(Spec Repo)来管理podspec
podspec文件(spec说明书)
创建pod库的时候会用到podspec文件将lib的一些信息,比如:版本号、作者名,链接地址等,以及其中用到的包括资源、源码、需要引用的framework,以及第三库等等组织起来
Spec Repo(存放spec的仓库)
Spec Repo,顾名思义,就是存放Spec文件的仓库,就是一个容器,所有公开的Pods都在这个里面,是一个Git仓库remote端.执行 pod setup命令会clone该仓库到本地的~/.cocoapods/repos目录下,可以进入到这个目录看到master文件夹就是这个官方的Spec Repo了。
Spec Repo仓库保存了依赖库的名称,版本号,以及spec文件.
因为Spec Repo存放了所有的spec文件,所以很明显它是一种集中式的依赖库管理工具.
创建公有Pod库或者私有Pod库, 实际上原理是一样的, 都是基于git服务和repo协议, 不一样的是, 两者的版本索引查询方式不一样, 公有库的podspec由CocoaPods/Specs管理, 而内部私有使用的pod库需要自己建立一个仓库来管理podspec.
好了,下面我们正式来构建私有的pod库
构建私有pod库
-
在公司的私有Git服务器上创建git仓库:盛放自己的功能组件
1. 必须有文件夹 2. 必须有LICENSE文件(这个好像是通用的,如果创建项目的时候没有,直接从其他项目中拷过来一个就行) 3. 必须有 库描述文件.podspec
-
在公司的私有Git服务器上创建git仓库用来做内部私有库的Spec Repo(盛放所有功能组件的spec)
"这个Spec Repo必须添加到本地,否则组件clone不下来" pod repo add 库的名字 库的地址 比如:pod repo add ymtSpecs git@git.yaomaitong.net:iOSPods/ymtSpecs.git 执行这个命令的人,必须得有这个库的操作权限 将ymtSpecs添加到本地repo, 添加成功后可以在/.cocoapods/repos/目录下可以看到官方的specs:master和刚刚加入的specs:ymtSpecs
-
编写自己库的podspec文件,自己的组件里放一份。
Pod::Spec.new do |s| s.name = "TestModule" s.version = "0.0.5" //版本号最好与组件中的tag保持一致,否则使用的时候拉取不到最新组件 s.summary = "Test" s.homepage = "http://gitlab.100credit.cn/xxx/TestModule" s.license = "MIT" s.author = { "yyy@163.com" => "yyy@163.com" } s.platform = :ios s.source = { :git => "http://gitlab.100credit.cn/xxx/TestModule.git", :tag => "#{s.version}" } s.source_files = "TestModule" //文件夹下全部拷贝,还有一种写法: TestModule/*.{h,m} end
将这个文件放到spec repo一份
1. 修改podspec中的version
2. 提交代码,打Tag,注意:这个tag记得要提价到origin,默认是只在工作副本中打Tag,"tag = podspec中的version"
3. pod repo push [Specs库名] Category.podspec 将podspec推送到 spec Repo中
遇到的问题
The NAME.podspec specification does not validate
用pod spec lint --verbose 验证一下,会打印出很多的详细信息,此时打印:The spec did not pass validation, due to 1 warning (but you can use `--allow-warnings` to ignore it).
所以,我重新使用pod repo push Specs xx.podspec --allow-warnings 就成功了
-
fatal: unable to access '...url...': Failed to connect to ...host... port 443: Operation timed out
更新某个库时,连接超时。
解决步骤:
1).pod repo
列出所有(公有库、私有库的)本地库,查看 cocoapods的本地库路径,一般都是.cocoapods/repos/master
2). 从报错信息中,可以看到操作失败的三方库的名称、版本号,使用shell命令find
进行查找
find ~/.cocoapods/repos/master -iname 名称
,会返回在本地库中的路径。前往该路径
3). 三方库文件夹下会有多个版本文件夹,找到报错信息中的版本号对应的文件夹,里面会有一个xxx.podspec.json
,替换json中source下git地址(可以直接Google,也可以在GitHub上搜索该库名称,看项目介绍,是否是这个库的镜像)。