组件化第一步:构建私有pod库

目的:

构建自己的一个组件,放在公司的私有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库

  1. 在公司的私有Git服务器上创建git仓库:盛放自己的功能组件

    1. 必须有文件夹
    2. 必须有LICENSE文件(这个好像是通用的,如果创建项目的时候没有,直接从其他项目中拷过来一个就行)
    3. 必须有 库描述文件.podspec
    
  2. 在公司的私有Git服务器上创建git仓库用来做内部私有库的Spec Repo(盛放所有功能组件的spec)

     "这个Spec Repo必须添加到本地,否则组件clone不下来"
         pod repo add 库的名字  库的地址
         比如:pod repo add ymtSpecs [email protected]:iOSPods/ymtSpecs.git
     执行这个命令的人,必须得有这个库的操作权限
     
     将ymtSpecs添加到本地repo, 添加成功后可以在/.cocoapods/repos/目录下可以看到官方的specs:master和刚刚加入的specs:ymtSpecs
    
  3. 编写自己库的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             = { "[email protected]" => "[email protected]" }
     s.platform     = :ios
     s.source       = { :git => "http://gitlab.100credit.cn/xxx/TestModule.git", :tag => "#{s.version}" }
     s.source_files = "TestModule"  //文件夹下全部拷贝,还有一种写法: TestModule/*.{h,m} 
    end
    
  4. 将这个文件放到spec repo一份

  1. 修改podspec中的version
  2. 提交代码,打Tag,注意:这个tag记得要提价到origin,默认是只在工作副本中打Tag,"tag = podspec中的version"
  3. pod repo push [Specs库名] Category.podspec 将podspec推送到 spec Repo中

遇到的问题

  1. 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 就成功了
  1. 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上搜索该库名称,看项目介绍,是否是这个库的镜像)。

参考文献: https://segmentfault.com/a/1190000007947371

你可能感兴趣的:(组件化第一步:构建私有pod库)