前言
随着公司业务与日俱增,写不完的需求,改不完的bug,实在令人头痛。为了简化开发任务,CocoaPods组件化开发是非常有价值和意义的。
- 不仅方便管理和沉淀已有的技术经验,也能形成自己的技术壁垒;
- 对于一些经常使用到的工具都可以通过Pods集成起来,一劳永逸;
- 使用方便,便于团队维护和开发,pods之间相互分离,调试成本大大降低;
- 拥有自己的编译系统,可以形成积木效应,根据需求搭配使用,提升开发效率;
正文
组件化开发已不是什么高深技术,且CocoaPods也是大家所熟知的依赖库管理工具,网络上已经有大量关于pod install的相关文章,本文在此不再复述,直接深入主题。
CocoaPods组件化开发的核心思想就是将我们经常用到的一些类库通过封装、抽象、接口暴露的形式提供给内部、或者外部使用的一种方式。
组件化又分两种思路:
- 开源,源码可访问,直接暴露代码
- 闭源,源码不可访问,提供静态库.a或者.framework
在此我们挑开源来讲,下面进入实战,以Gitlab为例:
- 新建工程(工程地址为你自己的工程地址,此处只做示范)
http://gitlab.xxx.xxx.com/app-ios-library/test.git
然后下载到本地workspace,cd进入项目工程 -
将需要集成为组件的source code放入该目录下
其中.podspec文件可以通过以下命令创建
touch podname.spec
- 编辑podspec描述
Pod::Spec.new do |s|
s.name = "yourpodname"
s.version = "0.0.3"
s.summary = "A Library for iOS to use for DataSync."
s.description = <<-DESC
"iOS yourpodname based on Objective-C, highly integrated, fast and easy to use. Fast integration. Minimum support for iOS7 systems."
DESC
s.platform = :ios, "7.0"
s.homepage = "[http://gitlab.xxx.xxx.com/app-ios-library/test.git](http://gitlab.xxx.xxx.com/app-ios-library/test.git)
"
s.license = "MIT"
s.author = { "youname" => "[email protected]" }
s.source = { :git => "[http://gitlab.xxx.xxx.com/app-ios-library/test.git](http://gitlab.xxx.xxx.com/app-ios-library/test.git)
", :tag => "#{s.version}" }
s.dependency '3rdLib','~> 0.2.4'
s.source_files = 'mqtt/MqttManager.{h,m}'
s.public_header_files = 'mqtt/MqttManager.h'
s.subspec 'mqtt' do |ss|
ss.subspec 'json_parser' do |sss|
sss.source_files = 'mqtt/json_parser/*.{h,m}'
sss.public_header_files = 'mqtt/json_parser/*.h'
end
ss.subspec 'source' do |sss|
sss.source_files = 'mqtt/source/*.{h,m}'
sss.public_header_files = 'mqtt/source/*.h'
end
ss.subspec 'gzip' do |sss|
sss.source_files = 'mqtt/gzip/*.{h,m}'
sss.public_header_files = 'mqtt/gzip/*.h'
end
end
end
- 验证本地Pod
pod lib lint --use-libraries --allow-warnings --sources=3rdlib --skip-import-validation --skip-tests --verbose
该命令将依赖于xcodebuild编译指定的source文件,
--use-libraries 开启库编译
--allow-warnings 允许告警
--sources=3rdlib 第三方依赖
--skip-import-validation 跳过验证
--skip-tests 跳过测试
--verbose 输出日志,
以上是pod本地库验证的具体参数,可根据不同需求进行指定
通过之后将看到以下内容:
MQTTClient passed validation.
紧接着提交代码到gitlab仓库,注意push前pull更新避免conflict
git commit -m 'commit content'
根据podspec描述的version创建tag
git tag -a v0.0.3 -m 'commit content'
提交tag
git push origin --tags
- 提交Pods
pod repo push podname podname.podspec --allow-warnings --sources=3rdlib --skip-import-validation --skip-tests --verbose --use-libraries
通过之后将会查看到,那么就大功告成了
Pushing the `yourpodname' repo
- 在项目中集成制作好的Pods
# Uncomment this line to define a global platform for your project
platform :ios, '10.0'
# Uncomment this line if you're using Swift
#use_frameworks!
target 'youProjectTarget' do
//3rd lib dependency
pod 'Masonry', '1.1.0'
//gitlab dependency
'http://gitlab.sz.sensetime.com/app-ios-library/test.git'
end
拓展
在深入一项技术时往往需要精通另外一些基础技术点,例如git的tag基本操作,平时用到的比较少,在此顺带整理一下
查看tag:git tag
创建tag:git tag -a v1.0.1 -m 'content'
提交tag:git push origin --tags
删除tag:git tag -d v1.0.1
删除remote server tag:git push origin --delete tag v1.0.1