苹果之美selector自动打包

podspec用法

2018-06-21  本文已影响4047人  GrayDang

下面来介绍下cocoapods的一些拓展用法。

Podfile

最基本的用法如下:

target 'BaseFramework' do
  # Uncomment the next line if you're using Swift or would like to use dynamic frameworks
  # use_frameworks!

  # Pods for BaseFramework

  pod 'AFNetworking', '~> 3.0'

  pod 'Masonry', '~> 1.0.2'

  pod 'SDWebImage', '~>3.7'

  target 'BaseFrameworkTests' do
    inherit! :search_paths
    # Pods for testing
  end

  target 'BaseFrameworkUITests' do
    inherit! :search_paths
    # Pods for testing
  end

end

通过上面的方法可以引入已经上传到Git上面并且打好tag的库。如果想更新了代码,则需要先push代码到github,然后打好新的tag才能实现对podfile的支持。
那如果不想把代码放到github上呢?我希望更新代码之后直接用pod update命令就可以把更新了的代码库引入我的工程。
可以用下面的写法:

pod 'BaseFramework', :path =>'../BaseFrameworkDir'

这个写法的意思是执行路径../BaseFrameworkDir下的BaseFramework.podspec文件,按照podspec文件已经编写好的规则来导入文件到工程里。

podspec文件

这里建议用命令行生成podspec文件,格式和注释都比较规范。

pod spec create XXX

接下来看看生成的podspec文件里比较重要的内容

s.name         = "BaseFramework" #工程的名字
s.version      = "0.0.1"  #工程的版本
s.summary      = "Gray's modularization BaseFramework."  #工程的摘要
s.description  = "Gray's BaseFramework demo"  #工程的描述
s.homepage     = "http://graydeng.BaseFramework"  #工程的首页
s.license      = "MIT"  #工程的证书
s.author       = { "Gray" => "denggray@163.com" } #工程的作者
s.ios.deployment_target = "8.0"  #工程的编译版本
s.source       = { :git => "http://graydeng/BaseFramework.git", :tag => "#{s.version}" }  #工程的git地址
s.source_files  = "Classes", "Classes/**/*.{h,m}"  #工程需要引入的文件
s.exclude_files = "Classes/Exclude"  #工程不需要引入的文件
s.public_header_files = "Classes/**/*.h"  #工程需要暴露出来的头文件
s.resources = "Resources/*"  #工程需要引入的资源文件(图片,xib等)
s.resource_bundles = {'Resources' => 'XXX.framework/Resources/XXX.bundle'} #工程需要引入的bundle
s.frameworks = "ImageIO"  #工程依赖的framework
s.vendored_frameworks = [] #工程依赖的第三方framework
s.libraries = "iconv", "xml2"  #工程依赖的library
s.vendored_libraries = []  #工程依赖第三方的library
s.requires_arc = true  #工程是否用arc规则
s.dependency "AFNetworking", "~> 3.0"  #工程依赖的第三方库

封装一个库最重要的还是source_files,把必须用到的文件导入到主工程。
其次就是资源文件resources、frameworks、libraries。
如果涉及到使用mrc的文件还需要设置一下requires_arc的参数

s.source_files  = "Classes/**/*.{h,m}"

这个配置表示在导入的时候会在Classes文件夹下找到所有的.h和.m文件并导入。

s.public_header_files = "Classes/**/*.h"

这个配置只在打包framework的时候起作用,选择暴露出来的头文件。

s.resources = "Resources/*"

这里配置工程的资源文件,包括图片、json文件、bundle文件等

s.frameworks = "ImageIO"

这个库依赖于系统库ImageIO,在pod入这个库的时候会带入这个系统库

s.libraries = "iconv", "xml2"

这个库依赖于系统Library iconv和xml2,在pod入这个库的时候会带入这个系统Library。注意这里Library的名字只取lib后面的字符。

s.dependency "AFNetworking", "~> 3.0"

工程依赖的第三方库,写法和podfile一致。

原文地址:https://graydang.github.io/2018/06/15/cocoapods/

上一篇下一篇

猜你喜欢

热点阅读