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" => "whqfor@126.com" }

 s.source  = { :git => "git@github.com: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文件相关知识整理

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,907评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,987评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,298评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,586评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,633评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,488评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,275评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,176评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,619评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,819评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,932评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,655评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,265评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,871评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,994评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,095评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,884评论 2 354

推荐阅读更多精彩内容