如何将自己的组件库使用CocoaPods管理

使用CocoaPods的好处

  • 未使用CocoaPods:集成的时候需要将源码拖到工程里面,手动添加组件需要依赖的系统库以及根据需要添加-ObjC-fno-objc-arc等配置,升级组件也需要重复之前的步骤
  • 使用CocoaPods:修改podfile文件后,一行命令集成,升级或移除组件库,不需要额外操作

安装CocoaPods

1.查看 Ruby 镜像源

gem sources -l

2.移除当前镜像源

gem sources --remove 当前镜像源

3.添加Ruby China 官方 RubyGems 镜像

gem source -a https://gems.ruby-china.com

为了验证是否更换成功,可以再执行一次gem sources -l来查看当前镜像
4.安装CocoaPods

sudo gem install cocoapods

使用CocoaPods管理组件

1.注册trunk
  • 不是任何人都能推送,因为cocoapods依赖trunk服务器管理,所以需要通过trunk推送自己的podspec
  • 命令:pod trunk register mail name ,mail是邮件地址,name是用户名
  • 收到邮件有点开链接访问一下就好了
2.podspec

Cocopods原理:根据Podfile描述,找到对应代码库的podspec文件
然后根据podspec中的描述,找到代码库,并且找到之后,拷贝需要的文件到自己的工程中。

  • 创建spec文件命令:pod spec create spec文件名

像图中的目录结构,该如何编写podspec文件呢

Pod::Spec.new do |s|
 
  #设置组件库的名称
  s.name         = "xxx"  

  #设置组件库的版本号
  s.version      = "5.4.9" 

  #组件库的简介
  s.summary      = "xxxxxx" 

  # 组件库的详情描述,要求比简介的字数多些
  s.description  = <<-DESC
                  xxxxxxxxxxx
                   DESC
  #设置仓库主页
  s.homepage     = "https://www.yuntongxun.com/"

  #设置许可
  s.license      = "MIT"

 #设置作者
  s.author       = { "xxx" => "xxx" }

 #设置支持的最低系统版本
  s.ios.deployment_target = "8.0"

 #设置仓库源,表示在哪可以找到组件工程(支持 git、svn、http 服务器)
  s.source  = { :git => "https://xxxxxxx", :tag => "#{s.version}" }
#s.source = { :svn => 'http://xxxxxxx', :tag =>  "#{s.version}" }
#s.source = { :http => 'http://xxxxxx/xxx.zip' }
  
 #资源文件
  s.resources  = "sdk/CCPSDKBundle.bundle"

 #设置源文件路径,不是整个工程的文件,而是自己封装的需要暴露出来的代码,以后别的工程引入,就会引入这里的代码。
  s.source_files = "sdk/*.h"
 
 #设置使用的静态库(非系统)
  s.vendored_library = 'sdk/*.a'

  #设置依赖库(系统),不需要 lib,例如: libicucore写成icucore即可
  s.libraries    = "resolv.9","icucore","sqlite3","z","xml2","bz2.1.0","c++"

 #设置依赖的 framework(系统),写的时候不需要后缀名
  s.framework    = "CoreTelephony","MediaPlayer","CFNetwork","SystemConfiguration","MobileCoreServices","AudioToolbox","AVFoundation","VideoToolbox"

 #设置使用的framework(非系统)
 # vendored_frameworks = ""

 #设置子目录
  s.subspec 'Delegate' do |ss|
  ss.source_files = "sdk/Delegate/*.h"
  end

  s.subspec 'enums' do |ss|
  ss.source_files = "sdk/enums/*.h"
  end

  s.subspec 'Manager' do |ss|
  ss.source_files = "sdk/Manager/*.h"
  end

  s.subspec 'private' do |ss|
  ss.source_files = "sdk/private/*.h"
  end

  s.subspec 'types' do |ss|
  ss.source_files = "sdk/types/*.h"
  #三级目录
  ss.subspec 'LiveChatRoomType' do |sss|
  sss.source_files = "sdk/types/LiveChatRoomType/*.h"
  end
  end

  s.subspec 'board' do |ss|
  ss.source_files = "sdk/board/*.h"
  end

  #设置组件库是否是基于 ARC 内存管理的,默认为 true,如果不是,会自动添加-fno-objc-arc 
  s.requires_arc = true

  #如果部分是ARC
  #spec.requires_arc = false
  #spec.requires_arc = ['Classes/*ARC.m', 'Classes/ARC.mm'] //指定 ARC 的文件

  #设置依赖的其他 pod 库
  # s.dependency "JSONKit", "~> 1.4"

  #设置xcconfig
  s.xcconfig = {
      'OTHER_LINKER_FLAGS' => '-ObjC',
      'ENABLE_BITCODE' => 'NO'
    }
end
  • 文件名匹配
    • *匹配所有文件
    • c*匹配以名字C开头的文件
    • *c匹配以名字c结尾的文件
    • *c*匹配所有名字包含c的文件
    • **文件夹以及递归子文件夹
    • ?任意一个字符(注意是一个字符)
    • [set] 匹配多个字符,支持取反
    • {p,q} 匹配名字包括p 或者 q的文件
  • 提交代码然后给自己的仓库绑定Tag,因为cocoapods是根据代码仓库的Tag,去下载对应Tag的远程代码库的。
3.验证pod 库
  • 命令:pod lib lint
  • 命令后加--verbose打印详细 log
  • 命令后加--allow-warnings当出现警告,但是不影响 pod 库的使用的时候会验证通过
  • 命令后加--use-libraries使用了自己的私有库,不加可能会验证不通过,加了就没问题
4.推送自己的podspec到cocoapods的索引库
  • 命令:pod trunk push --verbose --allow-warnings --use-libraries,后面的命令作用同上
  • 注意:必须cd 进入到podspec目录下,才能执行这个代码
  • 注意:podspec文件中的s.version版本号要跟最新tag一致
  • 注意:podspec文件中的s.source仓库地址也不能写错
5.测试能否索引到
  • 命令:pod search 组件库名称
  • 如果搜索不到自己的组件库,但是又pod trunk push成功了,说明本地pod索引库没有更新
  • 更新本地 pod 索引库
1.  rm ~/Library/Caches/CocoaPods/search_index.json
1.  pod setup
3.  pod search name
6.其他
  • 给增加其他维护者:pod trunk add-owner 组件库的名字 维护者的邮箱
  • 移除其他维护者:pod trunk remove-owner 组件库的名字 维护者的邮箱
  • 升级组件库:修改组件代码,打 tag,push 到远程代码库,修改 podspec文件中的 s.version重复步骤3,4,5即可
  • 移除组件库:
移除组件库的指令(name 为组件库名称,tag 是想要移除的版本号,如果要移除所有版本,不带 tag 就行):
1.  pod trunk delete name tag
2.  rm ~/Library/Caches/CocoaPods/search_index.json
3.  pod setup
4.  pod search name
7.可能遇到的问题

解决pod lib lint/repo push不支持i386编译&只能真机运行的库

  • 终端 gem which cocoapods
  • 进入/usr/local/lib/ruby/gems/2.5.0/gems/cocoapods-1.6.0.beta.1/lib
  • 在当前lib目录下有个cocoapods文件夹,找到validator.rb文件
  • 因为不能直接修改validator.rb文件,所以所以用命令:sudo vim validator.rb文件路径,输入密码后即可编辑,将上图红框中部分该成下面,这样就能绕过 pod lib lint 检测了
 # command += %w(CODE_SIGN_IDENTITY=- -sdk iphonesimulator)
 # command += Fourflusher::SimControl.new.destination(:oldest, 'iOS', deployment_target)
  command += %w(--help) #为了绕过模拟器检测不通过的 bug

基于本地pod库的组件化

上面讲到的方法是将组件库托管到公有远程仓库,任何人都可以下载集成组件库。但是有时候我们公司内部的一些大型项目也使用了组件化的方式来开发,这时候我们的组件库就不需要专门放到远程仓库来托管,照样也可以使用CocoaPods来管理。

  • 如图新建三个工程:MainTarget是主工程,ComponentA,ComponentB分别是两个不同的组件工程
MainTarget
ComponentA
  • 设置组件工程的 podspec文件
Pod::Spec.new do |spec|
  spec.name         = "ComponentA"
  spec.version      = "0.0.1"
  spec.summary      = "A short description of ComponentA."
  spec.homepage     = "https://www.yuntongxun.com/"
  spec.license      = "MIT"
  spec.author       = { "xxx" => "xxx@yuntongxun.com" }
  spec.source       = { :path => 'ComponentA.podspec' }
  spec.source_files  = "ComponentA/Class/*.{h,m}"
end

这里主要是spec.source组件路径要指向自身,其他的配置根据实际需要可以添加

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

推荐阅读更多精彩内容