iOS开发之CocoaPods:进阶篇 搭建私有库

经过入门篇中的实操,我们现在已经安装好了CocoaPods,也知道怎么导入依赖库了, 现在开始向前进一步,利用CocoaPods搭建私有库。

其实像AFNetworking这样的库,我们可以用CocoaPods导入是因为CocoaPods官方维护了一套库。那么其实我们也可以自己维护一套私有库,只供我们自己使用。

创建Pod项目工程

为什么Pod项目工程中的代码可以被导入?就像AFNetworking这个工程中的代码可以被我们导入,主要是因为项目中的podspec文件。

A specification describes a version of Pod library. It includes details about where the source should be fetched from, what files to use, the build settings to apply, and other general metadata such as its name, version, and description.
规范描述了Pod库的一个版本。 它包括有关应从何处获取源,要使用的文件,要应用的构建设置以及其他常规元数据(如名称,版本和说明)的详细信息。

创建Pod项目工程有两个方法:

  1. 手动创建podspec文件,这个方法更适合于把已有项目转为Pod项目

    $ pod spec creare [库名]
    
  2. 自动创建Pod项目工程,这个方法更适于一个Pod项目从无到有

    $ pod lib create [库名]
    

方法2创建的工程,会包含Demo工程,甚至可以包含单元测试框架,我自己更倾向使用此方法来做Pod。

pod lib create

Using Pod Lib Create

pod lib create 是Pod提供的一个自动化创建私有pod工程的命令,实质上是下载一个Pod工程模板到本地,再做修改。命令在运行过程中,会弹出几个配置项进行配置,按需设置就行,很简单。

$ cd ~/Desktop
$ pod lib create MyUtils
image

项目目录如下:

image
  • Example:Demo工程目录
  • MyUtils:库代码目录
  • LICENSE:开源证书
  • MyUtils.podspec:库的podspec
  • README.md:Readme

双击 MyUtils.xcworkspace 打开工程,工程结构如下:

image

接下来,我把这个工程放到了GitHub。

编写库代码

我这里就写一个测试类 MUAppInfo,写完之后再 pod install 进行开发模式下的导入

MUAppInfo.h

image

MUAppInfo.m

image

MUViewController.h

image

编辑podspec

podspec是这个pod的配置文件,当我们引用这个pod到工程的时候,就会按这个文件里的配置项进行配置。这边顺便提一下,podspec是Ruby文件,我们可以用 Visual Studio Code 再装上Ruby插件来编辑,真的很好用。

我对这个测试Pod的podspec做了简单编辑,具体配置项这里不细说了,可以查看Podspec Syntax Reference

Pod::Spec.new do |s|
  s.name             = 'MyUtils'
  s.version          = '0.1.0'
  s.summary          = 'A short description of MyUtils.'

  s.homepage         = 'https://github.com/kanggggg/MyUtils'
  s.license          = { :type => 'MIT', :file => 'LICENSE' }
  s.author           = { 'Kang' => 'xxxxx@gmail.com' }
  s.source           = { :git => 'https://github.com/kanggggg/MyUtils.git', :tag => s.version.to_s }

  s.ios.deployment_target = '8.0'
  s.source_files = 'MyUtils/Classes/**/*'
end

验证Pod是否可用

podspec写好了,接下来需要验证是否正确,这里有两个方法:

# pod spec lint 会去校验 s.source 的配置,也就是会去拉代码验证
$ pod spec lint # 不指定,默认当前文件夹内的podspec
$ pod spec lint MyUtils.podspec # 指定podspec

# pod lib lint 忽略 s.source 的配置,本地代码验证
$ pod lib lint # 不指定,默认当前文件夹内的podspec
$ pod lib lint MyUtils.podspec # 指定podspec

当看到终端打印 passed validation. ,就说明验证通过,不通过就根据提示进行修改。

当验证通过之后,打上tag,推送到远程仓库

$ git tag 0.1.0
$ git push origin --tags # 推送到远程

创建私有Specs repo

我们先打 ./cocoapods/repos 文件夹,会看到里面有个master文件夹,该目录即存放着官方的spec。我们自己添加的spec repo也会放在 ./cocoapods/repos 文件夹下。

  1. 先创建一个git仓库,https://github.com/kanggggg/MySpecs

  2. 添加到本地 repos 目录

    $ pod repo add MySpecs https://github.com/kanggggg/MySpecs.git
    

把私有Pod添加到私有 Specs repo 中

$ pod repo push MySpecs MyUtils.podspec

添加成功之后,就能看到 ~/.cocoapods/repos/MySpecs 多了 MyUtilsMySpecs 的远程仓库同步更新了。

测试工程导入私有库

这里拿出上面的 CocoaPodsDemo 这个工程进行测试,编辑Podfile ,编辑完成之后执行install

image

这里的重点在要指定source:

# 官方
source 'https://github.com/CocoaPods/Specs.git'

# 私有
source 'https://github.com/kanggggg/MySpecs.git'

私有库使用问答

私有库依赖私有库时验证不过

这个时候需要指定sources

$ pod spec lint <库名>.podspec --sources='私有Specs repo仓库地址,https://github.com/CocoaPods/Specs.git'

# 比如
# pod spec lint MyUtils.podspec --sources='https://github.com/kanggggg/MySpecs.git,https://github.com/CocoaPods/Specs.git'

私有库依赖私有库,推送到私有Specs repo

$ pod repo push <私有repo> <库名>.podspec --sources='私有Specs repo仓库地址,https://github.com/CocoaPods/Specs.git'

# 比如
# pod repo push MySpecs MyUtils.podspec 

pod验证过程中,发现修改的不生效

我们在验证pod的时候,可能会频繁的修改,但是有的时候修改了却还是之前的样子,再或者我们总是拉不到最新的代码老是老版本的,我们可以试着去清理缓存

# 查看缓存
$ pod cache list
  
# 清理全部缓存
$ pod cache clean --all

私有库依赖的其他三方library或者framework,不支持i386,导致 pod lib lint一直过不了,报 ld: symbol(s) not found for architecture i386

这个问题真的是很令人头疼,折腾了两天,也看了网上的一些解决办法,包括StackOverFlow,有成功的也有不成功的,成功的我也觉得不是最佳。我就去翻CocoaPods GitHub Issues,终于让我翻到了。

8129这个问题在 CocoaPods 1.6.0.beta.2 版本得到了修复

  1. 先升级到CocoaPods Beta版

    $ sudo gem install -n /usr/local/bin cocoapods --pre
    
  2. 编辑podspec,加入 pod_target_xcconfig

    s.pod_target_xcconfig = { 'VALID_ARCHS' => 'arm64 armv7 x86_64' }
    

    什么是 pod_target_xcconfig ?

    Any flag to add to the final private pod target xcconfig file.
    要添加到最终私有pod目标xcconfig文件的任何标志。

作者简介

就职于甜橙金融(翼支付)信息技术部,负责iOS客户端开发

欢迎大家移步本人的小博客 https://kanggggg.github.io/ ,不定时更新

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

推荐阅读更多精彩内容