pod私有库搭建及podspec编辑简介

简述

Cocoapods是个非常好的iOS依赖管理工具,可以方便的进行管理和更新使用到的第三方库,以及在做代码模组件化管理的时候,可以用它来管理私有库。

Cocoapods的安装、使用比较基础,这里不再赘述,网络上有很多资料。这篇文章主要介绍在Git环境下如何搭建自己的私有仓库,用以管理项目中的小模块。

在搭建自己的私有库之前先看一下pod的工作过程:

pod工作工程

当我们执行


$ pod search afnetworking

的时候会先搜索本地repo,其所在路径是~/.cocoapod/repos,如果本地没有则会默认执行


pod setup/pod update

去更新repo(将podspec文件下载到本地),这个过程比较慢,也可以自己去github下载完成后放到上面路径中。

cocoapods其实就是利用所维护的podspec文件,在使用方和提供方之间建立起一个桥梁,并利用与项目关联的pod项目去维护所有第三方。

如果想搭建一个自己的私有仓库,则在本地需要搭建一个自己的repo仓库来管理保存自己的podspec文件。

创建步骤


1.创建私有的Specs git库

2.在私有库项目中创建podspec文件

3.验证私有库的合法性

4.提交私有库的版本信息

5.向Spec Repo提交podspec

6.更新维护podspec

7.示例地址

1.创建私有的Specs git库

将私有repo 添加到 Cocoapods的格式是


$ pod repo add [repo名] [repo git地址]

举例:

a.首先创建一个Git仓库地址,例如https://github.com/xxx/HQSpecs,然后将其添加到Cocoapods列表中(多个工程podspec可以共用一个私有repo)。


$ pod repo add HQSpecs https://github.com/whqfor/HQSpecs.git

验证是否创建成功可以执行查看


$ pod repo list

创建成功后list中即会展现出刚才创建的repo


HQSpecs

- Type: git (master)

- URL: https://github.com/xxx/HQSpecs.git

- Path: /Users/whqfor/.cocoapods/repos/HQSpecs

master

- Type: git (master)

- URL: https://github.com/CocoaPods/Specs.git

- Path: /Users/whqfor/.cocoapods/repos/master

目前本地的私有repo是个空文件,先不要着急,一会还会对它进行操作,不需要手动更改。

2.在私有库项目中创建podspec文件

按照官方教程来编辑即可,下面是在写本文时创建的示例podspec


Pod::Spec.new do |s|

 s.name  = "TNetwork"

 s.version = "0.0.1"

 s.summary = "TNetwork base on AFNetworking and YTKNetwork."

 s.homepage  = "https://github.com/whqfor/TNetwork"

 s.license = 'Code is MIT, then custom font licenses.'

 s.author  = { "whqfor" => "[email protected]" }

 s.source  = { :git => "[email protected]:whqfor/TNetwork.git", :tag => "#{s.version}" }

 s.source_files = "TNetwork/**/*.{h,m}"

 s.public_header_files = 'TNetwork/**/*.h'

 s.requires_arc = true

 s.ios.deployment_target = "8.0"

 s.frameworks = "Foundation", "UIKit"

 s.user_target_xcconfig = { 'CLANG_ALLOW_NON_MODULAR_INCLUDES_IN_FRAMEWORK_MODULES' => 'YES' }

 s.dependency "AFNetworking", "~> 3.0"

 s.dependency "YTKNetwork"

end

如果不清楚的话,网上相应的文章挺多的,这一步并不复杂。

编写完之后放到git仓库下即可,和工程同级目录。

3.验证私有库的合法性

这是我在创建私有库时遇到问题最多的地方,尝试编译了半天。

在本地git仓库目录下,选择执行如下命令


pod lib lint (从本地验证你的pod能否通过验证)

pod spec lint (从本地和远程验证你的pod能否通过验证)

pod lib lint --verbose (加--verbose可以显示详细的检测过程,出错时会显示详细的错误信息)

pod lib lint --allow-warnings (允许警告,用来解决由于代码中存在警告导致不能通过校验的问题)

pod lib lint --help (查看所有可选参数,可选参数可以加多个)

这篇文章主要是介绍搭建私有仓库,所以首先验证本地pod是否能通过


$ pod lib lint --allow-warnings

执行这个命令的过程可能会花点时间,此外也会遇到各种错误。只需关注错误信息即可,最常见的是


error: include of non-modular header inside framework module

下面说下我在验证时总结的经验。


1\. 引入类,使用@class XXX; 不能像平时一样直接引入.h,可以在.m文件中引入。

2\. 引入协议,使用@protocol XXX; 。

3\. 当需要继承别的文件时,按照@class XXX;引入会报错,此时只能引入.h文件。

针对第3条,参考这篇文章给出了很多示例错误信息第7条,将


s.user_target_xcconfig = { 'CLANG_ALLOW_NON_MODULAR_INCLUDES_IN_FRAMEWORK_MODULES' => 'YES' }

这条加入到podspec中解决了问题,原理是改变了本工程Xcode的编译设置。

如果通过的话,会有相应的的提示


TNetwork passed validation.

4.提交私有库的版本信息

podspec文件中获取Git版本控制的项目还需要tag号,所以我们要打上一个tag,在工程目录下,终端执行


$ git tag -m "first release" "0.0.1"

$ git push --tags     #推送tag到远端仓库

5.向Spec Repo提交podspec

接下来将刚才的0.0.1版本的podspec提交到私有仓库中


$ pod repo push HQSpecs /Users/whqfor/TNetwork/TNetwork.podspec --allow-warnings

如果选择忽略警告的话可以加上--allow-warnings

6.更新维护podspec

之后如果需要发新的版本,和上诉流程基本一致,编辑好自己的库文件,打上tag提交到远端后,更新下podspec文件,执行第四步验证过之后,就可以继续按照第五步提交repo了。


~/.cocoapods/repos/HQSpecs 内的目录如下

├── LICENSE

├── TNetwork

│   ├── 0.0.1

│   │   └── TNetwork.podspec

│   └── 0.0.2

│       └── TNetwork.podspec

└── README.md

删除本地私有库


$ pod repo remove WTSpecs

还可以再添加回来


$ pod repo add HQSpecs https://github.com/CocoaPods/Specs.git

7.示例地址

在尝试的过程中,版本号没变化的话,之前pod install可能有缓存。在~/Library/Caches/CocoaPods/路径下找到缓存的库,直接删除即可。

HQSpecs仓库里放置的是podspec文件,有自己对应的git地址,podspec对应的仓库是另一个git地址,容易搞浑了。

以上即是只做了一个简单的私有库制作,后续会再完善下subspec制作,如果以后组件化的路上积攒更多的经验会持续更新。

本文HQSpec地址

本文podspec文件对应工程地址

参考文章

使用Cocoapods创建私有podspec

Cocoapods整理(三)——编写podspec文件

podSpec文件相关知识整理

你可能感兴趣的:(pod私有库搭建及podspec编辑简介)