前言
Cocoapods是一个依赖管理工具,使用它可以方便的管理和更新项目中所使用到的第三方库,也可以管理自己的私有库,让工程模块化。本文主要介绍如何 通过Cocoapods管理私有库。
正文
主要流程
1、建立两个Git仓库
2、编写podSpec文件
3、检查podspec
4、提交podspec
5、使用cocoapods引入
6、版本更新
建立两个GIt 仓库
一个用于管理私有库的源码,一个用于管理podSpec文件。
cocoapods管理私有库工作原理为:通过podfile 文件中的git地址拉取podSpec文件,通过podSpec文件中的源码git地址管理私有库的源码,并根据配置完成相关依赖。
编写podSpec 文件
可以选择自己根据规格写一个podSpec文件(后缀名.podspec)
或者执行pod spec create
,创建一个模板podspec 文件,再根据需要进行修改
格式如下:
Pod::Spec.new do |spec|
spec.name = 'Reachability'
spec.version = '3.1.0'
spec.license = { :type => 'BSD' }
spec.homepage = 'https://github.com/tonymillion/Reachability'
spec.authors = { 'Tony Million' => 'tonymillion@gmail.com' }
spec.summary = 'ARC and GCD Compatible Reachability Class for iOS and macOS.'
spec.source = { :git => 'https://github.com/tonymillion/Reachability.git', :tag => 'v3.1.0' }
spec.source_files = 'Reachability.h,m'
spec.framework = 'SystemConfiguration'
spec.requires_arc = true
spec.libraries = "stdc++"
end
注意:
有些代码需要引入一些底层库才能执行的,需要在 spec.libraries
填写,如代码里有C++代码,需要引入stdc++,所以填写spec.libraries = "stdc++"
如需引入如“AFNetworking”之类的三方库即需要填写s.dependency = 'AFNetworking'
如需引入framework即需要填写spec.framework
参数spec.source
需填写代码所在的git地址,并指定相应的tag或者commit
检查podspec文件
cocoapod提供了命令行进行podspec文件校验:
pod lib lint
一般使用时会带一些参数,如:
pod lib lint --allow-warnings --use-libraries --verbose
--allow-warnings
:允许有警告
--use-libraries
使用依赖库
--verbose
提供更详细的信息方便追踪问题。
注意:在podspec文件所在目录执行该命令。
提交podspec
完成podspec文件的校验后,将其push到其所在的git仓服务器端。
通过一下命令行添加本地文件
pod repo add 文件名 [podspec文件的git地址]
使用cocoapods引入
在Podfile加入podsepc文件的git地址,并填写pod 'podSpec文件名 '
如:
source 'https://github.com/CocoaPods/Specs.git'
platform:ios,'8.0'
target "Fenqile" do
pod 'AFNetworking', '~> 3.1.0'
source 'http://gitlab.fenqile.com/public_iOS/podSpecRepo.git'
pod 'podSpec文件名 '
end
再通过pod install 命令引入
版本更新
当模块化的代码需要更改时,更改podspec文件中的spec.source
还有版本号。
接着在podspec文件所在的目录下执行,进行更新
pod repo push 文件名 podspec文件 --allow-warnings --use-libraries --verbose
完成之后执行pod update
命令进行更新。