创建只有自己能Pod的私有库

  对于iOS开发者来说,Cocoapods无疑是一个非常好用的三方库管理工具,在开发过程中,我们也会使用到许多优秀的三方库。有时候我们也需要将自己的东西封装起来并重复利用,但是又不想像Cocoapods上一样让别人用,这时我们就需要建立自己的私有库。

  想要上传自己的私有库,需要先弄懂Cocoapods的原理及目录结构。Cocoapods一共分为两块,即CocoapodsSpecs,Specs实际上是一个目录容器,所有的三方库的podspec文件都在里面,那么podspec文件又是什么呢,podspec文件就相当于每一个三方库的介绍文件,包含名字、版本、以及三方库的下载地址等,步骤三会详细介绍。

  使用过cocoa pods的同学在本地都会有一个.cocoapods/repos文件夹,这个文件夹就是在使用cocoa pods时自动从Specs上clone到本地的,即路径~/.cocoapod/repos,进入本地看看目录结构:

repos->master->Specs->[Name]->[Version]->[Name].podspec

  没错,这个是公有的三方库的目录,我们做私有库,就是要模仿公有库的结构目录,建立一个自己的Spec的私有仓库来维护,这个仓库可以是私有也可以是公开。总的来说,我们需要维护的东西有两个,一个是私有的Specs目录,一个是我们需要上传的三方库。

一、创建私有的Specs目录

在远端建一个仓库,命名为MySpecs,把仓库clone到本地,把公有Specs里面的CocoaPods-version.yml文件拷贝到里面,并建立一个名为“Specs”的文件夹,(文件夹里面可以放一个无关的小文件,要是是空文件夹推到远端可能会被忽略),然后把东西推动远端仓库,私有Specs创建完成。如图:

二、将远端的私有Specs仓库clone到本地.cocoapods目录下

$ pod repo add MySpecs https://xxxx@bitbucket.org/xxxx/Myspecs.git 

在终端执行上述命令,记得将仓库地址改正。执行成功的话,在本地~/.cocoapods/repos路径下就能发现,多了一个MySpec的文件夹。

三、创建pod spec文件

我必须说这一步尤为重要

我必须说这一步尤为重要

我必须说这一步尤为重要

重要的事情说三遍。

准备工作:1、将需要作为三方库的所有文件整理在工程的一个文件夹下(为后续方便),并上传至远端。

                2、打开终端cd 到本地工程下。

执行命令:

$ pod spec create [Name] https://xxxx@bitbucket.org/xxxx/xxxx.git

注:其中Name是三方库的名字,地址是作为三方库的工程的远端地址。

完成后在当前目录下回生成一个叫做[Name].podspec的文件。打开这个文件(建议用sublime打开,sublime很好用,另外sublime的负责人看到了记得打赏广告费,谢谢!)里面注释相当详细,我这里列举几个重要的:

s.name        = "xxxx"     #三方库名字

s.version      = "0.0.1"     #版本号,建议从0.0.1开始(官方的版本号是不能删除和向下修改的,只能递增,但私有库是我们自己维护的,所以可以随意修改)

s.summary      = "xxxxxxxx"    #三方库总结

s.description  = "xxxxxxx"       #三方库描述

s.homepage  = "https://xxxxxxx"       #主页信息(填写项目仓库的地址即可)

s.license      = "MIT"  #开源协议,一般填MIT(注:.podspec

文件同目录下必须要有一个MIT开源协议文件,如果没有,去github上别人的目录下随便拷贝一个)

s.author            = { "xxxxxx" => "xxxxxx@163.com" }#作者姓名、邮箱,不用我说了吧

s.platform    = :ios, "7.0" #支持的系统版本

s.source      = { :git => "https://xxxx@bitbucket.org/xxx/xxx.git", :tag => "0.0.1" }#资源地址,很重要,pod install的时候根据这个地址去下载三方库,另外为避免麻烦,版本号必须与s.version中的版本号一致。

s.source_files = ""#这个很重要,指定资源文件,前缀就是.podspec文件当前路径,只用写之后的路径,如Class/*是指Class文件夹下的所有文件,但不包括子文件夹里面的文件、Class/**/*是指包含所有Class文件夹下的文件,包括子文件、Class/**/*.{h,m}是指包含所有Class文件夹下的后缀为.h或.m的文件,当然也可以指定文件。

s.requires_arc = true#是否支持arc

#######以下的为可选

#s.resource  = "icon.png"#资源文件,包括图片和xib文件

# s.dependency "JSONKit", "~> 1.4"#需要依赖的三方库

#s.framework  = "SomeFramework"#需要依赖的框架

#s.public_header_files = ''#公开的头文件,如果不没公开,用户在用的时候可能引不到响应的头文件

s.subspec 'subFolder' do |ss|

ss.source_files = 'Class/xxx/**/*.{h,m}'

ss.public_header_files = "Class/xxx/**/*.{h}"

end#这个是子依赖库,因为如果我们只是用s.source_files来指定文件,那么用户在pod下来之后所有的文件都在同一个目录下,没有子文件夹,如果想要分下类,用s.subspec,每一个subspec可以分一个子文件夹,但是记得一定要将.h文件通过ss.public_header_files公开,不然有可能会找不到头文件。

差不多这些重要的,可以根据库的复杂度酌情修改,然后保存。

如有不明白的可以和我讨论,或者去参考其他的如:AFNetworking等的podspec文件。

四、验证

打开终端,cd到.podspec文件的目录下,使用命令:

$ pod lib lint

如果有错,按照错误修改podspec文件,如果通过,那么恭喜你完成一大部分了。

当然为了验证你的文件路径指定对不对,我们可以做一个测试,找一个新工程,在Podfile文件中加入

pod '[Name]', :podspec => '/Users/xxxx/Desktop/xxx/xxx.podspec'

注:[Name]为pod spec中的s.name,必须一致,后面的路径为本地pod spec文件的路径。

然后打开终端cd到当前Podfile目录下执行

pod install

pod install --no-repo-update

第二条命令是不更新官方Specs至本地,速度要比第一条快。

执行完成之后,打开工程看看Pods下的三方库的结构是不是跟你想象的一样,并可以测试能不能用。

五、向Specs远端提交.podspec文件

通过验证后,给当前代码打上tag,建议tag和版本号一致,并推送到远端(官方的tag是不能向下修改的)

$ git tag '0.0.1

$ git push origin --tags

将tag推送到远端之后,向自己的私有库提交podsepc文件:

$ pod repo push MySpecs [Name].podspec

如果提交成功,这时候去到~/.cocoapods/repo/MySpecs文件夹下就发现多了一个文件夹,正是你刚刚创建的三方库。

到这里,恭喜你的私有库创建完成。


六、使用

不出意外,这个时候,你去终端pod search 你的三方库名字,就能搜到(如果你的名字和官方Specs里面的某个三方库名字一样的话将会搜不到),使用的时候在Podfile中加入两个Specs源即:

官方源:

source 'https://github.com/CocoaPods/Specs.git'

私有源:

source 'https://xxxxx@bitbucket.org/xxxxx/Myspecs.git'#即你的私有源仓库地址


当然,你也可以指定地址

pod 'xxxx', :git =>'https://xxxx@bitbucket.org/xxxx/xxxx.git'

这里的地址是你的三方库的远端地址。二选一都行,为了避免冲突,建议用第二种。

把自己踩过的坑记录下来,希望对正在研究的同学有帮助。

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

推荐阅读更多精彩内容