cocoapods-发布组件库到trunk

相关:
1- 发布组件库到私有索引库spec

  • 前提: 先执行 pod search <名字>,查看在cocoapods官网上,是否已有同名的第三方库,避免后面麻烦;

一、创建仓库

  • 仓库名为组件名字;
  • Readme文件不用勾选;
  • 访问级别:private、public;

两者不同,代表索引库的开放权限:
private:SDK私有,需要授权才能pod集成;
public:所有人都可以pod集成;

创建好后,先放置一边;

二、创建本地组件代码库

先进入(cd)到想放组件的文件夹下;

  • 1- 创建索引项目
pod lib create <组件名>
//如: pod lib create MySDK
  • 2- 执行后,会出现一系列的选择,按照步骤进行选择就OK;
What is your email?
What platform do you want to use?? [ iOS / macOS ]  //选择平台:iOS
What language do you want to use?? [ Swift / ObjC ] //选择语言:ObjC
Would you like to include a demo application with your library? [ Yes / No ]  //是否自动生成一个demo:Yes
Which testing frameworks will you use? [ Specta / Kiwi / None ]  //None
Would you like to do view based testing? [ Yes / No ] //No
What is your class prefix? //生成类的前缀
  • 3- 最终生成一个组件项目,会自动打开项目;在项目的目录下,其中有个Example的目录,打开就可以看到目录结构;
    工程目录.png

三、在组件项目中添加组件

  • 在这个项目中,ClassesAssets文件夹就是放组件文件的地方;
  • ReplaceMe.m这个文件,是生成项目时,自动生成的,可以删除;
  • Classes放入组件的文件,Assets组件放资源文件;
项目目录.png

四、pod组件到项目中

  • cd Example,到Example目录,有Podfile文件的地方;
  • 执行pod install;
  • 执行完毕后,在项目目录可以看到组件已pod到工程中;
pod目录.png

五、索引文件XXX..podspec

打开工程的XXX..podspec文件,根据需要修改;

Pod::Spec.new do |s|
  s.name             = 'MySDK' //SDK名字
  s.version          = '0.1.0' //版本号,和GitHub上的tag要保持一致
  s.summary          = 'A short description of MySDK.' //简介

  s.description      = <<-DESC
  TODO: Add long description of the pod here. //描述,可以是个链接URL
                       DESC

  s.homepage         = 'https://github.com/[GitHub名字]/MySDK'
  # s.screenshots     = 'www.example.com/screenshots_1', 'www.example.com/screenshots_2'
  s.license          = { :type => 'MIT', :file => 'LICENSE' } //开源默认证书
  s.author           = { 'XXX' => 'XXX@qq.com' } //作者
  s.source           = { :git => 'https://github.com/[GitHub名字]/MySDK.git', :tag => s.version.to_s } //项目地址和tag
  # s.social_media_url = 'https://twitter.com/<TWITTER_USERNAME>'

  s.ios.deployment_target = '9.0'

  # s.source_files = 'MySDK/Classes/**/*' //pod库的源文件
  s.vendored_frameworks = "MySDK/Classes/*.framework" //pod库中framework的路径
  
  # s.resource_bundles = {
  #   'MySDK' => ['MySDK/Assets/*.png']
  # }
  s.resource         = "MySDK/Assets/*.bundle" //指定的资源直接复制到客户端目录
  s.pod_target_xcconfig = { 'VALID_ARCHS[sdk=iphonesimulator*]' => '' }

  # s.public_header_files = 'Pod/Classes/**/*.h' //pod库暴露给用户工程的头文件
  #s.frameworks = 'UIKit', 'MapKit' //依赖的系统库
  s.dependency 'AFNetworking', '~> 4.0.1' //依赖的第三方库
  
end

六、提交到远程仓库

在工程根目录下执行,即在XXX.podspec所在的文件夹

git add .
git commit -m "第一次添加组件"
git remote add origin <GitHub仓库地址>
git push origin master
git tag <版本号> (和XXX.podspec里的一致,如:0.1.0)
git push --tags

七、验证cocoapods索引文件

在工程根目录下执行,即在XXX.podspec所在的文件夹;

  • 1- 进行检验
pod spec lint --verbose --allow-warnings
//或
pod spec lint --skip-import-validation --allow-warnings --use-libraries 

pod spec lint --verbose --use-libraries --allow-warnings --sources='git@私有库地址.git,https://github.com/CocoaPods/Specs.git'

  • 2- 校验成功:
XXX.podspec passed validation.
  • 3- 校验失败
    会标出错误的说明,可以根据说明进行处理;
[!] The spec did not pass validation, due to 1 error.
失败信息
失败结果

八、发布

在工程根目录下执行,即在XXX.podspec所在的文件夹;

  • 1- 先查看是否注册trunk;
pod trunk me
已注册
  • 2- 如果没有注册,则先注册
pod trunk register <邮箱xxx@qq.com> "<名字>" --verbose

注册完成后,会发送一个确认邮件,里面有链接,点击后,确认;
注册完毕后.

  • 3- 发布SDK (在工程根目录下,有XXX.podspec的目录)
pod trunk push xxx.podspec 
//或
pod trunk push xxx.podspec --allow-warnings //允许警告
//或
pod trunk push xxx.podspec --allow-warnings --skip-import-validation //跳过验证pod是否导入

  • 4- 发布成功
Updating spec repo `trunk`
Validating podspec
  -> MySDK (0.1.0)

Updating spec repo `trunk`

--------------------------------------------------------------------------------
 🎉  Congrats

 🚀  MySDK (0.1.0) successfully published
 📅  January 26th, 00:41
 🌎  https://cocoapods.org/pods/MySDK
 👍  Tell your friends!
--------------------------------------------------------------------------------

九、验证

  • 将组件发布cocoapods成功后,可以使用search命令搜索;
pod search <库名字>
  • 查找成功
-> MySDK (0.1.0)
   A short description of MySDK.
   pod 'MySDK', '~> 0.1.0'
   - Homepage: https://github.com/[GitHub名字]/MySDK  //对应XXX.podspec配置的
   - Source:   https://github.com/[GitHub名字]/MySDK.git
   - Versions: 0.1.0 [trunk repo]
  • 查找失败,会出现红色一行字,提示找不到
  • 原因:
    1- 发布成功后,需要隔一段时间,可能是还在审核中;
    2- 可能第二天早上执行以下,就可以找到了;
[!] Unable to find a pod with name, author, summary, or description matching `MySDK `

可以尝试以下方式:

//进入搜索CocoaPods缓存目录
cd ~/Library/Caches/CocoaPods
//查看缓存文件search_index.json
ls
//删除搜索缓存文件
rm -f search_index.json

有时候pod search找不到的情况下,可能直接使用pod install就安装成功了,得到意想不到的结果;

pod 'MySDK' //podfile中添加
pod install //执行安装

查询已发布到trunk的库

更新已发布的库

// 1-先修改XXX.podspec里面的tag
s.version = '0.1.0' 

// 2- 更新改动到远程仓库
git push origin master

// 3- 打tag,和XXX.podspec里面的tag一致;
git tag <版本号> 
git push --tags

//4- 校验
pod spec lint --allow-warnings --skip-import-validation --use-libraries 
//5- 发布
pod trunk push xxx.podspec --allow-warnings --skip-import-validation

执行pod trunk push xxxx遇到的问题

1- 原因:原因是身份认证失效


invalid

Authentication token is invalid or unverified. Either verify it with the email that was sent or register a new session.

解决方案:重新验证身份

pod trunk register 'xxx@qq.com' 'yourname' --description='描述~'  
//然后到邮箱点击验证的链接;
//重新执行:pod trunk push xxxx

相关资料:

pod spec lint官网资料说明

--verbose //显示详情信息
--use-libraries //组件有依赖,迭代组件版本的时候,需要加上--use-libraries
--allow-warnings //允许警告
--skip-import-validation //跳过校验pod是否可以导入
pod spec lint --verbose 
pod spec lint --use-libraries
pod spec lint --allow-warnings

两种校验方式的区别:

  • 两者和s. source填入的内容是相关的;
pod lib lint  //校验本地
pod spec lint  //校验本地和远程github,只有校验成功了,才能将

资料:cocoapods官网

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

推荐阅读更多精彩内容