iOS 创建CocoaPods公有库

大部分同学可能已经掌握了如何正确创建CocoaPods公有库了,网上也有很多详细的文章,笔者之所以写这篇文章是因为自己记性不好,方便自己和像我一样的人查阅,顺便把自己项目里用到的东西分享给大家,而且这些东西真的没必要一定记住,就像其它不常用的API一样,能记住更好,忘记了再查阅一下。

本文以 钥匙串工具类:YXYKeyChainManager 制作过程为例。

pod 'YXYKeyChainManager', '~> 0.0.1'

CocoaPods使用框架的过程图 引用他人

image.png

一、创建公有Pod库

1、注册CocoaPods账户信息(已注册过请略过)
创建一个开源pod库, 首先我们需要注册CocoaPods账户, 使用trunk方式在终端执行:

pod trunk register '邮箱地址' '用户名'  --description=‘描述内容’ --verbose

可以使用GitHub邮箱和用户名, 然后在你的邮箱中会收到确认邮件, 在浏览器中点击链接确认即注册成功, 成功之后可以终端执行:

pod trunk me
image.png

2、创建共享库文件并上传到公有仓库
共享库三要素:

2.1、 共享文件夹(文件夹存放着你要共享的内容, 也就是其他人pod得到的文件, .podspec文件中的source_files需要指定此文件路径及文件类型);
2.2、LICENSE文件(默认一般选择MIT);
2.3、库描述文件.podspec(本库的各项信息描述, 需要提交给CocoaPods, pod通过这个文件查找到你共享的库)。

这一步分两种情况:
A、使用现有的想要共享的文件,不提供示例,只需满足上面三个部分,即可上传到公有仓库继续其他的步骤(本文使用的情况);
B、创建一个全新带有示例工程的项目做共享, 可以使用终端命令:

pod lib create '库名'

注:两种情况实际没什么区别,主要区别就是 A:无示例,B:创建带有模板示例。
3、创建仓库

3.1、在GitHub创建一个仓库,建议仓库与项目同名'YXYKeyChainManager':


1.jpg

3.2、仓库克隆到本地(笔者使用的sourceTree)


2.jpg
3.jpg

3.3、创建.podspec文件(路径及项目名根据实际情况替换)

cd /Users/yxy/YXYKeyChainManager
pod spec create YXYKeyChainManager.podspec
4.jpg

3.4、创建Classes文件夹并拖入源代码文件


5.jpg

4、编辑.podspec文件

Pod::Spec.new do |spec|

  spec.name         = "YXYKeyChainManager"
  spec.version      = "0.0.1"
  spec.summary      = "钥匙串工具类"
  spec.description  = <<-DESC
                      钥匙串工具类:用于方便向钥匙串中存取数据而实现的类。
                      类中包含常用的增、删、改、查方法。
                   DESC

  spec.homepage     = "https://github.com/FreeYXY/YXYKeyChainManager"
  spec.license      = "MIT"
  spec.author             = { "YXY" => "yxyxiao90@163.com" }
  spec.source       = { :git => "https://github.com/FreeYXY/YXYKeyChainManager.git", :tag => "#{spec.version}" }
  spec.source_files  = "Classes", "YXYKeyChainManager/Classes/**/*.{h,m}"
  # spec.platform     = :ios
  # spec.platform     = :ios, "5.0"
  #  When using multiple platforms
  # spec.ios.deployment_target = "5.0"
  # spec.osx.deployment_target = "10.7"
  # spec.watchos.deployment_target = "2.0"
  # spec.tvos.deployment_target = "9.0"
  # spec.exclude_files = "Classes/Exclude"
  # spec.public_header_files = "Classes/**/*.h"
  # spec.resource  = "icon.png"
  # spec.resources = "Resources/*.png"
  # spec.preserve_paths = "FilesToSave", "MoreFilesToSave"
  # spec.framework  = "SomeFramework"
  # spec.frameworks = "SomeFramework", "AnotherFramework"
  # spec.library   = "iconv"
  # spec.libraries = "iconv", "xml2"
  # spec.requires_arc = true
  # spec.xcconfig = { "HEADER_SEARCH_PATHS" => "$(SDKROOT)/usr/include/libxml2" }
  # spec.dependency "JSONKit", "~> 1.4"

end

这是一个最简单的.podspec文件样式, 各项属性的意思一目了然。

编写完成后需要验证.podspec文件的合法性, 终端执行:

// 若已在此工程目录忽略cd命令
cd /Users/yxy/YXYKeyChainManager
pod lib lint YXYKeyChainManager.podspec

相关命令(可选择使用):

//本地验证
pod lib lint      
//本地和远程验证   
pod spec lint    
// 显示详细的检测过程,出错时会显示详细的错误信息
pod lib lint --verbose
//允许警告,用来解决存在警告导致不能通过校验的
pod lib lint --allow-warnings  

7.jpg

验证成功:
6.jpg

5、打tag、 发布一个release版本(笔者使用sourceTree,可使用命令行)终端命令:

git tag -m '0.0.1'
git push --tag #推送tag到远端仓库

打完tag,将代码推送至git远程仓库,tag版本号必须与.podspec文件中version一致,

spec.version      = "0.0.1"

成功之后即可在你的GitHub-releases里面看到这个tag的版本.


image.png

6、发布自己的库描述文件.podspec至cocoapods同样在这个文件夹下, 终端执行(--allow-warnings忽略警告):

pod trunk push YXYKeyChainManager.podspec --allow-warnings

将你的库文件.podspec文件提交到公有的specs上面,此命令包含验证.podspec文件是否合法+提交到specs中)+将上传的podspec文件转成json格式文件)。
成功后显示:


image.png

7、关于查找和使用新创建的库
成功直接pod search YXYKeyChainManager 查看是找不到的,解决办法终端输入:

//pod setup成功后生成的~/Library/Caches/CocoaPods/search_index.json文件, 是用来查找的索引文件
rm ~/Library/Caches/CocoaPods/search_index.json

删除~/Library/Caches/CocoaPods目录下的search_index.json文件, 删除成功后再执行:pod search '库名', 等待输出:Creating search index for spec repo 'master'.. Done! 稍等片刻就会出现你想要的结果~


image.png

image.png

8、更新维护podspec
后续需要版本迭代,修改工程文件后推送到远端仓库后, 需要修改podspec中的版本号, 并重新打tag上传, 再进行新一轮的验证和发布。

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