CocoaPods创建自己的开源库和私有库

通过CocoaPods创建开源库、私有库,最关键的是*.podspec的编写。
如果电脑上还未安装CocoaPods,可以参考:新版CocoaPods的安装

创建项目和.podspec文件

如果你已经有了项目代码,可以使用pod命令创建.podspec

# 项目路径下
pod spec create 'KMPinHeaderLayout'

如果还没有项目,可以使用:

pod lib create 'KMPinHeaderLayout'

根据命令行的提示和引导,会为你创建一个模板工程和.podspec文件、README.md文件、MIT LICENSE文件等。

编辑.podspec文件

文件内容可以根据模板和注释来修改和填写,对其中一些内容进行记录说明:

  1. s.source_files 指明哪些源文件会被包含进去,比如s.source_files = "KMPinHeaderLayout/Classes/**/*.{h,m}",多条之间用逗号,分隔,用**表示匹配所有子目录,用*表示匹配所有文件,.{h,m}表示匹配其中的.h和.m文件。其中的路径是以.podspec所在目录为根目录。

  2. s.exclude_files 规则同上,指定不被包含的文件、目录。

  3. s.license,一般写法有s.license = 'MIT's.license = { :type => 'MIT', :file => 'LICENSE' }LICENSE对应.podspec所在目录下的名为LICENSE文件。

  4. 指定可用平台和版本,s.platform = :ios, "7.0"s.ios.deployment_target = '7.0'。如果支持多个平台应该使用后者,并指定其他平台的版本如s.osx.deployment_target = "10.7"

  5. s.public_header_files,公开的头文件,如果指定,在pod lint验证时,会以framework的形式验证,一般可以不用这个配置。

  6. s.framework(s)s.libraries,指定依赖的系统库。两者内容都需要去除后缀,其中s.libraries需要去除前缀lib,如静态库依赖是libz.tbd,则s.libraries = 'z'

  7. s.vendored_librariess.vendored_frameworks如果开源库中是一个静态库,使用这个指定静态库。如微博的podspecs.vendored_libraries = 'libWeiboSDK/libWeiboSDK.a'

  8. s.xcconfig 指定项目配置,如HEADER_SEARCH_PATHSOTHER_LDFLAGS等,e.g s.xcconfig = { "OTHER_LDFLAGS" => "-ObjC" }

  9. s.resource(s) 指定包含的资源文件。

  10. s.dependency 指定依赖,如s.dependency = 'AFNetworking'

  11. s.source 指定源,s.source = { :git => 'https://github.com/sleepEarlier/PinHeaderLayout.git', :tag => s.version.to_s }
    更多信息可以查阅官方:http://guides.cocoapods.org/syntax/podspec.html

示例:

Pod::Spec.new do |s|
  s.name         = "KMPinHeaderLayout"
  s.version      = "0.1.0"
  s.summary      = "Float header for collectionview, support both vertical and horizon."
  s.description  = <<-DESC
  A custom UICollectionViewFlowLayout support float header just like UITablebiew section header does.
                   DESC
  s.homepage     = "https://github.com/sleepEarlier/PinHeaderLayout"
  s.license      = { :type => "MIT", :file => "LICENSE"}
  s.author       = { "sleepEarlier" => "xxx@qq.com" }
  s.platform     = :ios, "7.0"
  s.source       = { :git => "https://github.com/sleepEarlier/PinHeaderLayout.git", :tag => s.version }
  s.source_files  = "CollectionView/*Layout.{h,m}"
  s.ios.deployment_target = "7.0"
  s.framework  = "UIKit"
  s.requires_arc = true
end


验证podspec

验证命令:

pod lib lint KMPinHeaderLayout.podspec --verbose

--verbose会给出详细的信息。
--allow-warnings允许警告,默认有警告的podspec会验证失败。
--fail-fast 遇到错误马上停止,默认会完成全过程再停止。
--use-libraries 如果项目中引用了.a.framework,在验证和提交时需要加。
--sources 如果此podspec 依赖了其他不包含在官方specs里的pod,则用它来指明源,比如依赖了某个私有库。多个值以逗号分隔。

由于我们在podspec的source中指定了tag,因此一般需要先打tag并push,再来验证:

# tag 0.1.0
git tag 0.1.1

# push tag
git push --tags

但是这样有一个问题,如果验证失败了,这个tag相当于无效了,我们需要删除tag重打:

# 删除本地tag 0.1.0
git tag -d 0.1.0

# 删除远端tag 0.1.0
git push origin --delete tag 0.1.0

当多次验证失败时上面的步骤就略显繁琐,因此,我们可以先在.podspec中不指定tag:

s.source       = { :git => "https://github.com/sleepEarlier/PinHeaderLayout.git", }


这样会在验证时,产生一个没有tag的警告,我们使用--allow-warnings来允许警告

pod lib lint KMPinHeaderLayout.podspec --verbose --allow-warnings

等验证通过后,我们再编辑podspec中的tag,并打tag然后push到远端。
最好在push tag后再进行一次验证,以防万一。由于已经打了tag,所以这一次验证不需要加--allow-warnings


发布podspec

查看当前PC是否注册:

pod trunk me

如已注册,会显示相关信息,否则进行注册:

pod trunk register xxx@example.com "some description" --verbose

命令会向CocoaPods注册一个账号,如果切换电脑需要重新执行命令注册,注册命令中的description可以用来区分不同的设备。

发布podspec

pod trunk push KMPinHeaderLayout.podspec

如果在验证时,使用了--allow-warnings--use-libraries,则在发布时也需要加上相同的选项。

搜索自己的pod

发布成功后,会把podspec更新到官方的repo中,也可以在CocoaPods官网搜索到自己的pod。
也可以执行下面的命令来搜索:

pod search KMPinHeaderLayout

但是...有时候你发现,在官网搜到了,但是你在终端执行pod search...时结果却是:

pod search KMPinHeaderLayout
[!] Unable to find a pod with name, author, summary, or description matching `KMPinHeaderLayout`

由于pod search 是在本地的~/.cocoapods/repos/master/Specs中进行搜索的,上面的结果可能是由于
①. 本地的Specs不是最新的,我们可以进行更新,然后重新搜索:

pod repo update --verbose

②. 还是搜不到?可能是因为搜索的缓存导致,删除缓存重新搜索:

# delete cached index
rm ~/Library/Caches/CocoaPods/search_index.json

# search again
$ pod search KMPinHeaderLayout 


私有仓库

创建私有仓库与上面的步骤类似,区别是:

创建仓库

需要先创建仓库:

pod repo add 'repoName' 'repo URL'
# e.g
pod repo add 'KMPinHeaderLayout' 'http://internal.git.com/sleepEarlier/PinHeaderLayout.git'


编辑podspec

方法与上文中一样。

验证podspec

方法与上文中一样,如果依赖了其他私有库,需要使用--sources指定source。
注意,依赖关系不能出现闭环,比如A依赖B,B依赖C,C依赖A。

pod lib lint PinHeaderLayoutpodspec --sources=https://github.com/CocoaPods/Specs.git,http://interal.git.com/sleepEarlier/Specs.git


发布podspec

pod repo push 'KMPinHeaderLayout' KMPinHeaderLayout.podspec

如果依赖了其他私有库,需要使用--sources指定source。

使用私有库

可以直接在Podfile中使用

platform :ios, '10.3'

target 'PointerTest' do
  # Pods for PointerTest
  pod 'PinHeaderLayout', :git => 'http://internal.git.com/xxx/PinHeaderLayout.git'
end

必要时,可以在Podfile中列出source

source 'http://interal.git.com/sleepEarlier/Specs.git'

platform :ios, '10.3'

target 'PointerTest' do
  # Pods for PointerTest
  pod 'PinHeaderLayout', :git => 'http://internal.git.com/xxx/PinHeaderLayout.git'
end

很多时候,在开发过程中,我们希望在开发私有库的过程中,修改代码后不用一直打tag并执行pod update,我们可以这样写Podfile:

# 本地路径
pod 'PinHeaderLayout', :path => '~/Desktop/PinHeaderLayout'

这样在普通的修改代码时,不需要重新打tag并pod update,但是当工程结构有变化(文件移动,增删等)、podspec修改,最好执行一次pod update

参考文章:

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

推荐阅读更多精彩内容