首先看这篇文章之前,已经默认你已经懂的怎么通过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