(一)CocoaPods组件化开发

前言

随着公司业务与日俱增,写不完的需求,改不完的bug,实在令人头痛。为了简化开发任务,CocoaPods组件化开发是非常有价值和意义的。

  1. 不仅方便管理和沉淀已有的技术经验,也能形成自己的技术壁垒;
  2. 对于一些经常使用到的工具都可以通过Pods集成起来,一劳永逸;
  3. 使用方便,便于团队维护和开发,pods之间相互分离,调试成本大大降低;
  4. 拥有自己的编译系统,可以形成积木效应,根据需求搭配使用,提升开发效率;

正文

组件化开发已不是什么高深技术,且CocoaPods也是大家所熟知的依赖库管理工具,网络上已经有大量关于pod install的相关文章,本文在此不再复述,直接深入主题。

CocoaPods组件化开发的核心思想就是将我们经常用到的一些类库通过封装、抽象、接口暴露的形式提供给内部、或者外部使用的一种方式。

组件化又分两种思路:

  • 开源,源码可访问,直接暴露代码
  • 闭源,源码不可访问,提供静态库.a或者.framework

在此我们挑开源来讲,下面进入实战,以Gitlab为例:

  1. 新建工程(工程地址为你自己的工程地址,此处只做示范)
    http://gitlab.xxx.xxx.com/app-ios-library/test.git
    然后下载到本地workspace,cd进入项目工程
  2. 将需要集成为组件的source code放入该目录下


    (一)CocoaPods组件化开发_第1张图片
    3362360-68e2a9f8f81d255a.png

    其中.podspec文件可以通过以下命令创建

touch podname.spec
  1. 编辑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
  1. 验证本地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
  1. 提交Pods
pod repo push podname podname.podspec --allow-warnings --sources=3rdlib --skip-import-validation --skip-tests --verbose --use-libraries

通过之后将会查看到,那么就大功告成了

Pushing the `yourpodname' repo
  1. 在项目中集成制作好的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

你可能感兴趣的:((一)CocoaPods组件化开发)