代码发布到cocoapods

发布 Git 管理的代码至Cocoapods

1. 创建.podspec文件

Git 管理的代码都会有 .git 文件。首先打开终端, cd 到与.git 同级的目录。
执行命令:

$ pod spec create <NAME> 

<NAME> 替换成所要发布的项目的名称。例如

$ pod spec create RTDatabase

执行成功,终端会有途中所示提示。


终端执行成功提示

2. 编辑.podspec文件

打开文件项目文件目录,找到 *.podspec文件,双击打开。如果打不开,选择Xcode 或者 Sublime Text打开。第一次打开会有一百多行,看起来很吓人。先把注释(.podspec中以#开头的是注释)删除。

-> 大概留着么多东西就行了,需要的可以再添加进来。

Pod::Spec.new do |s|
  s.name         = "RTDatabase" # 要发布项目的名称,要与.podspec同名
  s.version      = "0.0.1"  # 版本号
  s.summary      = "A short description of RTDatabase." # 项目概括
  s.description  = <<-DESC            
                   DESC  # 项目描述。可以没有,但有这一项就要有内容。

  s.homepage     = "http://EXAMPLE/RTDatabase" # 个人主页
  s.author             = { "ENUUI" => "ENUUI_C@163.com" } # 作者,以及联系方式。

  s.license      = "MIT" # 发布的证书,不知道证书可以去了解一下。

  # s.requires_arc = true # 是否是arc的
  # s.platform     = :ios     #  运行环境
  # s.ios.deployment_target = "5.0"  #  运行环境,与所支持的系统版本
  # s.osx.deployment_target = "10.7"
  # s.watchos.deployment_target = "2.0"
  # s.tvos.deployment_target = "9.0"

  s.source       = { :git => "http://EXAMPLE/RTDatabase.git", :tag => "#{s.version}" } 

   # 项目源文件目录
 s.source_files  =  "Classes/**/*.{h,m}"
  # s.public_header_files = "Classes/**/*.h"  # public头文件目录

  # s.dependency "JSONKit", "~> 1.4"  # 依赖的第三方
  # s.ios.frameworks = 'MobileCoreServices', 'CoreGraphics' # 依赖的系统库
end

这样以来就一目了然了,稍稍有点英语基础,就能看出来每一项的含义是什么。

s.source = { :git => "http://EXAMPLE/RTDatabase.git", :tag => "#{s.version}" }

  • 其中http://EXAMPLE/RTDatabase.git可以替换成托管代码的git网站上的git clone用的网址,如https://github.com/FuihuiC/RTDB.git
    也可替换成项目的.git目录,如/Users/ENUUI/Desktop/Codes/OptiDB/RTDB/.git
  • #{s.version}则一项建议就不要该了,这个的意思是,项目资源的release版本与.podspec中的s.version项中的版本号相同。

s.source_files = "Classes/**/*.{h,m}"
s.public_header_files = "Classes/**/*.h"

这两项非常类似。刚开始的时候这个目录还是很容易出问题的。

  • 目录起始要与.podspec所在的目录同级;
  • 其中的*代表任意长度的任意的任意字符;
  • {h,m}中填写文件后缀,出了h,m,还有swift等,多项以,隔开;
  • s.public_header_files = "Classes/**/*.h"这一项只会声明公开的头文件,不会按照路径去加载。所以要保证这一项中的头文件都已经在s.source_files加载,或者单独加载。

比如s.source_files = 'RTDatabase/core/RT*.{h,m}'.这句的意思是:RTDatabase/core/路径下,所有以RT开头的.h.m文件。

检测本地pod是否通过。

  • 执行命令: $ pod lib lint <NAME>.podspec --allow-warnings
  • <NAME>替换成自己的.podspec文件的名字,不保留尖括号。

3. 创建release版本

(1) Git 托管网站创建release版本

所有的 Git 托管网站都差不太多,以 GitHub 为例。

  • 首先,确保代码都已经提交完成。点击release。
点击release
  • 然后,点击Draft a new release
    点击创建新的release
  • 在新建release界面,图示1位置填写索要创建release的版本号。可以选择分支,起个标题,填写当前版本的描述。其中,版本号是必填的。填写完成后,点击Publish release,新的release就创建好了。
    在新建`release`界面

创建完成后,一定要git pull一下,将新版信息pull到本地。

(2)本地创建release
  • 打开终端,cd.git所在目录,执行命令:
// <version>位置填写要创建的 tag 的版本号。没有尖括号。
$ git tag -a <version> -m '<message>'
  • 如果要提交到 Git 服务器,执行下命令:
// <version> 填写要提交的 tag 的版本号。没有尖括号。
$ git push origin <version>
  • 删除本地 tag
$  git tag -d <version>  //删除本地tag
  • 删除远程tag
$ git push origin <version> //删除远程tag
// 或者
$ git push origin --delete tag <version>  //删除远程tag

4. 发布

  • 首先,检测文件的有效性,执行命令:
$ pod spec lint --allow-warnings

执行结果显示*.podspec passed validation(一般是绿色的)时成功。

  • 发布到cocoapods,执行命令:
$ pod trunk push <NAME>.podspec --allow-warnings

这个过程可能会慢一些,耐心等待就可以了。当出现一些彩色的小图案,并有Tell your friends!字样的时候,说明已经成功了。

5. 问题

  • 路径问题。在添加资源的时候,路径一定要写清楚,不能错点。
  • 代码错误。代码有问题是传不上去的。
  • 没有把 Git 服务器上的release拉到本地。

6.示例

文中提到的代码 RTDatabase
RTDatabase 的 .podspec

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

推荐阅读更多精彩内容

  • 最近公司同时进行两个项目的开发,而这两个项目有一些共同的文件,比如:聊天消息管理类,第三方登陆分享管理类等等。如果...
    奔跑的时间阅读 250评论 2 0
  • 一、概述 Cocoapods是当前iOS开发最流行的版本依赖工具,开发者使用Cocoapods进行项目的依赖管理会...
    Doliant_H阅读 2,441评论 3 26
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,580评论 18 139
  • 1,CocoaPods的简单介绍以及使用 我这篇文章主要介绍如何将项目发布到CocoaPods上,安装以及简单实用...
    李连毛阅读 1,182评论 1 7
  • 时间总是匆忙 你来看我 只有半天 看了电影 吃了饭 逛了超市 然后各自回家
    wuli元芳阅读 162评论 0 0