iOS 坑的集中营iOS Developer程序猿阵线联盟-汇总各类技术干货

实现CocoaPods的subspec分支功能

2017-05-17  本文已影响151人  踩坑小分队

首先看这篇文章之前,已经默认你已经懂的怎么通过CocoaPods集成远程共有或者私有的Pods了,如果还不了解,可以参考
1、教你一步步用CocoaPods创建远程公有库
2、教你一步步用CocoaPods创建远程私有库
subspec最终实现的效果是什么样子的呢?为什么要用这个东西呢?

效果是这个样子的

image.png

为什么要用这个东西呢?
因为我们封装的一段代码,可能是有好几段之间没有联系的代码拼起来的。而有的时候,我们只想用我们封装的代码的某一段或者某几段,比如现在,我们就只想用AFNetworking/Reachability (3.1.0)
我们的Podfile中只需要这么写就OK了

image.png

.podspec文件,相关修改语法是这样的


Pod::Spec.new do |s|
  # 项目的名称
  s.name             = 'DownLoader'
  # 项目的版本号,通过项目git的tag标签进行对应,这里的标签代表的版本
  s.version          = '0.1.1'
  # 项目简单的描述信息
  s.summary          = '简单的下载器##0.1.1'

  # 项目的详细描述信息,注意,这里的文字的长度,一定要比上面的s.summary长,不然会认为格式不合格
  s.description      = <<-DESC
简单的下载器,支持断点下载
                       DESC
  # 项目的网页主页信息,这里可以直接写自己的远程仓库的主页的地址
  s.homepage         = 'https://coding.net/u/WANG19931123/p/DownLoader'
  # 截图
  # s.screenshots     = 'www.example.com/screenshots_1', 'www.example.com/screenshots_2'
  # 开源协议
  s.license          = { :type => 'MIT', :file => 'LICENSE' }
  # 作者信息
  s.author           = { 'zy_ios@163.com' => 'zy_ios@163.com' }

  # 这个比较重要,指的就是git的对应的远程仓库的地址以及版本号,版本号直接获取的是上面的s.version
  # 项目地址,这里不支持ssh的地址,验证不通过,只支持HTTP和HTTPS,最好使用HTTPS
  s.source           = { :git => 'https://WANG19931123:password@git.coding.net/WANG19931123/DownLoader.git', :tag => s.version.to_s }
  # 多媒体介绍地址
  # s.social_media_url = 'https://twitter.com/<TWITTER_USERNAME>'
  # 支持的平台及版本
  s.ios.deployment_target = '8.0'
  # 代码源文件地址,**/*表示Classes目录及其子目录下所有文件,如果有多个目录下则用逗号分开,如果需要在项目中分组显示,这里也要做相应的设置
  # s.source_files = 'DownLoader/Classes/**/*'

  s.subspec 'Category' do |category|
  category.source_files = 'DownLoader/Classes/Category/**/*'
  category.dependency 'AFNetworking', '~> 3.0'
  category.dependency 'YYModel
  end

  s.subspec 'DownLoader' do |downLoader|
  downLoader.source_files = 'DownLoader/Classes/DownLoader/**/*'
  end

  # 资源文件地址
  # s.resource_bundles = {
  #   'DownLoader' => ['DownLoader/Assets/*.png']
  # }
  # 公开头文件地址
  # s.public_header_files = 'Pod/Classes/**/*.h'
  # 所需的framework,多个用逗号隔开
  s.frameworks = 'UIKit'
  # 依赖关系,该项目所依赖的其他,当在加载的时候也会一块把相关的依赖的库加载下来,如果有多个需要填写多个
  # s.dependency 'AFNetworking', '~> 2.3'
  # 是否使用ARC,如果指定具体文件,则具体的问题使用ARC
  s.requires_arc = true
end

image.png
pod search DownLoader
image.png

最终的实现效果是这样的


image.png
上一篇 下一篇

猜你喜欢

热点阅读