CocoaPods创建公共、私有库

1、git服务器创建一个项目。
2、Clone项目到本地,到本地后是一个空目录,还没有工程。
截屏2021-06-10 下午3.05.51.png

3、创建一个工程。
1.打开终端,切换到该目录

cd /Users/apple/Desktop/Silence/reference/LXLAlertView

2、创建工程模板

pod lib create LXLAlertView

3、配置相关选择。

选择平台

What platform do you want to use?? [ iOS / macOS ]
iOS

选择语言

What language do you want to use?? [ Swift / ObjC ]
ObjC

是否自动生成demo,选择Yes,方便以后测试

Would you like to include a demo application with your library? [ Yes / No ]
Yes

是否集成测试框架

Which testing frameworks will you use? [ Specta / Kiwi / None ]
None

UI 测试

Would you like to do view based testing? [ Yes / No ]
No

指定类前缀

What is your class prefix?
LXL

截屏2021-06-10 下午3.10.16.png

4、执行完之后,自动打开项目。

截屏2021-06-10 下午3.08.06.png

4、编写podspec文件。

1、 目录下文件介绍

  • podspec这个文件主要是用来描述项目名称、pod的版本号、介绍、首页(homepage)、作者信息、git源等,具体的可以参看官方Podspec Syntax Reference

  • README使用过GitHub的都会知道README文件的重要性,这个文件可以使用Markdown语法,主要展示在GitHub工程上的首页。README文件对于使用这个pod库的人来说,有和没有这个文件,区别是很明显的,此外这还有助于创建一个高质量的 CocoaPods Quality Index

  • LICENSE要想是Spec仓库接收,就必须包含一个license。命令pod lib create 自动创建使用的是 MIT license;

2、如果用第3步的命令创建工程模板,那么工程的目录下已经自动生成了.podspec(XesAppMultimedia.podspec)。如果是已有的工程或者库文件目录,也可以利用Pod命令自己制作.podspec文件,命令如下:

pod spec cretae <组件库名>

PS注意:自动生成的podspec文件只是模板,需要结合工程的库文件、资源目录、远程代码仓库(第1步创建的远程代码仓库)修改补充podspec文件。

5、验证.podspec文件的格式是否正确
1、cd 到 *.podspec 文件所在的目录下,用到的一些命令

pod lib lint
解说:本地验证pod能否通过验证,如果失败使用下面命令:pod lib lint --verbose查看失败原因, 或使用pod lib lint --allow-warnings忽略警告错误

pod spec lint
解说:本地和远程验证pod能否通过验证,需要更新提交podspec到远程specs仓库,参考第7步,一般本地验证通过即可提交到远程specs仓库

pod lib lint --verbose
解说:加--verbose可以显示详细的检测过程,出错时会显示详细的错误信息

pod lib lint --verbose --allow-warnings
解说: 允许警告,用来解决由于代码中存在警告导致不能通过校验的问题

有时候会提示一个错误:

截屏2021-06-10 下午3.12.33.png

没有写简介,把简介填写一下,就可以验证通过。

有时候会提示一个错误:

截屏2021-06-10 下午3.12.53.png

到这个提示错误信息的时候,使用如下指令:

pod lib lint 文件名称.podspec --use-libraries --allow-warnings

相应的执行上传指令的时候,也需要加上参数:

pod repo push GofSpecs GofKit.podspec --use-libraries --allow-warnings

pod lib lint --sources=[https://git.xxx.com/LXLAlertView...]
解说: 私有库依赖需要添加specs源来验证

引用当前私有库的podFile中指定source为私有库地址

source http://[privateLibName]/cocoaspecs.git'
source 'https://github.com/CocoaPods/Specs.git'

pod lib lint --help
解说:查看所有可选参数,可选参数可以加多个

6.提交工程代码

提交工程代码到远程代码仓库,可以利用git或者svn进行代码版本管理,提交代码到GitHub等, 初始化提交命令如下:

//初始化git版本管理仓库,模板代码已经初始化过此步骤可以忽略(有.git文件夹)
git init

//添加到暂存区
git add .

截屏2021-06-10 下午3.14.00.png

//提交到本地仓库
git commit -a -m '提交信息'
示例:git commit -a -m '添加pod组件库'

//打标签,注意此标签可能在podspec中用到,用于区分版本
git tag 1.0.0

//本地仓库与远程仓库关联(已关联过的,可以忽略)
git remote add origin <url>

//拉取和合并本地与远程仓库
git pull origin master --allow-unrelated-histories

//本地仓库代码推送到远程
git push --set-upstream origin master

此时如果你报错,查看报错信息中如果有:“pre-receive hook declined”
说明存在权限问题,没有master分支的代码提交权限。分配权限后,就可以push成功。

//推送标签
git push --tags

7.提交podspec文件

  1. 开源库提交
    podspec文件到Cocopods官方仓库,首先在cocopods官方仓库中注册账号,命令如下:

pod trunk me

//(检查是否注册trunk)

pod trunk register 邮箱 注册名字 --verbose
//(注册命令)

注册完成之后会给你的邮箱发个邮件,进入邮箱邮件里面有个链接,需要点击确认一下.之后开始提交,切换到有.podspec文件的组件工程根目录执行命令

pod trunk push 组件库名.podspec
pod trunk push 组件库名.podspec --allow-warnings

  1. 私有库提交
    私有仓库需要先添加到本地仓库,再push到远程仓库。
    电脑查看目录:~/.cocoapods/repos/

添加到本地仓库, git@git.xxxx/.git为远程specs库的地址,成功之后目录(~/.cocoapods/repos)除了master之外,新增了一个文件夹(组件库名)

pod repo add specs仓库名 specs远程仓库地址
//示例:pod repo add LXLAlertView https://####.com/ /LXLAlertView_ spec.git

查看是否添加成功

pod repo list

push到远程specs仓库

pod repo push 本地spec库名 本地.podsepc文件
//示例:pod repo push LXLAlertView LXLAlertView.podspec

如果.podspec文件存在警告时不能成功push。

解决:Pod repo push 本地spec库名 本地.podsepc文件 --allow-warnings
示例:pod repo push LXLAlertView LXLAlertView.podspec --allow-warnings

如果已经添加过得,可以不用再添加。
如果添加报错:
删除文件夹, 重新pod repo add, 重新pod repo push

pod repo add LXLAlertView https://####.com/ /LXLAlertView spec.git

pod repo push specs远程仓库地址 组件库名.podspec
//示例:pod repo push https://##.com/#/LXLAlertView_ specs.git LXLAlertView.podspec

8、 检查仓库是否发布成功
pod搜索验证:

pod search 组件库名

如果报错,搜索不到,建议更新下pod:

pod update

之后仍然搜索不到,那么进入CocoaPods缓存目录,删除缓存索引文件search_index.json:

cd ~/Library/Caches/CocoaPods
ls
rm -f search_index.json

9、 pod库文件引入
如果是开源库(公有的),修改podfile文件:

如果是私有仓库,建议在podfile文件开头添加source源:

最后执行命令进行安装:

pod install

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

推荐阅读更多精彩内容