CocoaPods 创建私有Pod

此处省略一万字……
废话不多说,直接进入正题!

一、创建我们需要pod的项目

1.另起一个路径,执行如下命令:
$ cd ~/Desktop/
//这个命令的作用是创建一个pod项目,它会自动给你生成spec文件
$ pod lib create DYCategoryKit
//pod lib create NAME使用默认模版,如果想使用其他模版,可以添加--template-url=URL参数。
//pod lib create NAME:创建标准目录结构、模板文件。pod lib create NAME不是创建pod的唯一方法,但它是最简洁的方法
2.执行完这个命令之后会有如下几个选项,根据你的需求填写就👌了
image.png
  • What platform do you want to use?? [ iOS / macOS ],选择iOS,直接回车默认选择第一个
  • What language do you want to use?? [ Swift / ObjC ],选择Swift。CocoaPods会把你的库设置为framework。
  • Would you like to include a demo application with your library? [ Yes / No ],选择Yes。如果你想要包含一个示例工程,或计划在app中测试你的库,这里需要选择Yes,以便模板文件为你的库创建Xcode工程。也就是如果你计划为pod添加截图,这里需要选择Yes。
  • Which testing frameworks will you use? [ Quick / None ],选择Quick。提交库到CocoaPods前应当进行测试。CocoaPods推荐使用其附带的测试framework,而非Apple的XCTest。在Objective-C中,可以选择Specta/Expecta或Kiwi,其区别如下:
    Specta/Expecta:通过不同podspecs的模块化方法。
    Kiwi:是对Stubs/Mocks/Expections的一种一体化方法。
    CocoaPods已经在MyLib-Tests.pch文件中添加了所有必要的包含和设置,因此不必将它们包含在每个文件中。
  • Would you like to do view based testing? [ Yes / No ],选择Yes。根据你建立的仓库,你可能会发现基于快照的测试是验证视图不同部分不同操作的最佳方法,这里建议使用FBSnapShotTestCase。如果你使用的是Specta/Expecta,那么其会包含一个pod来改进语法。
  • What is your class prefix?如果你选择的语言是ObjC,其最后会要求提供类前缀
3.选项填完之后回车,会自动创建一个项目,名称就是DYCategoryKit
4.在DYCategoryKit里面有两个文件夹
Assets:存放图片资源等等
Classes:存放源码,默认会有一个ReplaceMe.m文件 (比如SDWebImage pod里的类文件)

我们只需要把要上传的代码放入Classes文件即可,如果需要查看更改后demo效果,在Example中pod update即可更新修改的文件.

5.在github或gitlab上创建新的pod项目,这里我创建的地址是https://github.com/Sandyln/DYCategoryKit.git
6.进入YCategoryKit项目,修改podspec文件,这里可以用Sublime Text或者Xcode (文本编辑器不推荐,因为可能会改变"的格式,造成lint不通过),我这里直接在xcode中进行更改,根据你的需要进行相应更改。
  Pod::Spec.new do |s|
  s.name             = 'DYCategoryKit' //名称,pod search 搜索的关键词,注意这里一定要和.podspec的名称一样,否则报错
  s.version          = '0.1.0' //版本号
  s.summary          = 'A short description of DYCategoryKit.' //简介
  s.description      = <<-DESC
  TODO: Add long description of the pod here.
                       DESC
  s.homepage         = 'https://github.com/SenDylan/DYCategoryKit' //项目主页地址
  s.license          = { :type => 'MIT', :file => 'LICENSE' } //许可证
  s.author           = { 'SenDylan' => '*******' } //作者
  s.social_media_url: //社交网址,你的podspec发布成功后会@你
  s.source           = { :git => 'https://github.com/SenDylan/DYCategoryKit.git', :tag => s.version.to_s } //:项目的地址
  s.ios.deployment_target = '8.0' //支持的pod最低版本
  s.source_files = 'DYCategoryKit/Classes/**/*' //需要包含的源文件
  s.resources: 资源文件
  s.requires_arc: 是否支持ARC
  s.dependency:依赖库,不能依赖未发布的库,如果有多个可以写多个s.dependency
7.执行$ pod lib lint --allow-warnings (--verbose加上显示详情)
//pod lib lint NAME:验证你创建的pod是否符合规范,是否可以通过CocoaPods使用。
-> DYCategoryKit (0.1.0)
DYCategoryKit passed validation.
//如果用到了私有Pod
$ pod lib lint --sourcehttps://github.com/SenDylan/DYSpecs.git,https://github.com/CocoaPods/Specs.git --allow-warnings
//如果用到了lib 静态库
$ pod lib lint --sourcehttps://github.com/SenDylan/DYSpecs.git,https://github.com/CocoaPods/Specs.git --use-libraries --allow-warnings

终端如此显示便是lint成功了.

8.继续执行如下命令
$ git remote add origin https://github.com/SenDylan/DYCategoryKit //这里是你需要pod的项目地址,不是私有库的地址
$ git add .
$ git commit -m "注释描述"
$ git push origin master
//注意:如果你创建项目的时候生成了README或者license文件,那么这里你push的时候可能会push不了,如是你可用
$ git push origin master -f 强制提交,会覆盖之前的文件
9.为仓库打tag,这个tag需要和spec文件中的版本保持一致
$ git tag -m "你的描述" 0.1.0
$ git push --tags

二、创建私有的spec文件仓库(类似公共的CocoaPods Specs

1.首先在github或gitlab上创建一个空项目,这里起名为DYSpec.
2.在终端执行如下命令:
//pod repo add 私有库索引名字 github/gitlab 项目地址
$ pod repo add DYSpecs  https://github.com/SenDylan/DYSpecs.git
  • pod repo add 执行完毕后,cocoapods 会把DYSpecs clone 在 ~/.cocoapods/repos 目录

三、关联库

1.将你的代码库(DYCategoryKit)关联到索引库里(DYSpecs)
//执行如下命令
// pod repo push 最开始建立的私有库名称 pod项目中的spec文件,--allow-warnings --verbose 忽略警告,打印详细日志
$ pod repo push DYSpecs DYCategoryKit.podspec --allow-warnings
Validating spec --allow-warnings --verbose
 -> DYCategoryKit (0.1.0)
Updating the `DYSpecs' repo
Your configuration specifies to merge with the ref 'refs/heads/master'
from the remote, but no such ref was fetched.
Adding the spec to the `DYSpecs' repo
 - [Add] DYCategoryKit (0.1.0)
Pushing the `DYSpecs' repo
2.创建成功之后可能会出现search不到的情况,此时可删除本地搜索索引,然后再进行搜索
$ rm ~/Library/Caches/CocoaPods/search_index.json
$ pod search DYCategoryKit
3.私有仓库的使用你应该懂的,需要在Podfile添加source源
//如果还要添加公有pod,还需要加上这行
source 'https://github.com/CocoaPods/Specs.git'
//私有pod仓库索引
source 'https://github.com/SenDylan/DYSpecs.git'
platform :ios, "8.0"  
target "XXX" do  
    pod 'DYCategoryKit','~>0.1.0'  
end

Tips: 后期改动代码提交只需修改1.6的版本号重复1.7~1.9,3.1即可 小技巧:防止项目中的文件误操作可进行加锁:终端执行chmod 444 文件路径

四、私有Pod1引用私有Pod2

1.修改podspec文件
在 Pod1.podspec 文件 中添加 s.dependency '私有库名', '~>版本号' 
Podfile 添加 source 'Pod2 索引地址' 
用到共有库 添加共有索引地址 source 'https://github.com/CocoaPods/Specs.git'

五、错误信息

  • .Encountered an unknown error (Unable to find a specification for xxxx depended upon by xxxx
$ pod lib lint --sourcePod2索引地址() --allow-warnings

Example:pod lib lint --sourcehttps://github.com/SenDylan/DYSpecs.git,https://github.com/CocoaPods/Specs.git --allow-warnings
  • Remote branch not found in upstream origin
$ git tag 'v0.0.1'
$ git push --tags
  • The PodTest.podspec specification does not validate.
可能你用到了lib 静态库,在命令行加上
$ pod repo push DYSpecs DYCategoryKit.podspec  --use-libraries --allow-warnings

参考自:这里

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