podspec书写规范

简单的参数:

s.name         = "BaseFramework" #工程的名字
s.version      = "0.0.1"  #工程的版本
s.summary      = "Gray's 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。

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

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

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

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


s.resources = "Resources/*"
//  mj导入资源
s.resource = 'MJRefresh/MJRefresh.bundle'

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


s.frameworks = 'UIKit','Foundation'

frameworks配置用到了哪些系统的framework,比如UIKit,Foundation,这种设置是强引用,表示必定需要。

还有一种弱引用的方法,使用weak_framework,

s.weak_framework = 'MetricKit' // 弱引用系统库,添加单个
s.weak_frameworks = 'MetricKit','VisionKit' // 弱引用系统库,添加多个

使用场景,比如MetricKit 是iOS13之后才有的框架,在13系统之前引用会到出现镜像加载失败,启动直接崩溃。使用s.weak_framework  , 可以保证在高版本系统上正常使用,低版本系统上无影响。


s.ios.vendored_frameworks = "xxx/**/*.framework"
s.ios.vendored_libraries = "xxx/**/*.a”

 vendored_frameworks, 引用自己或第三方的framework时

vendored_libraries, 引用自己或第三方的.a文件时


s.libraries = 'z','resolv'
----
s.library = 'sqlite3'

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


s.dependency "AFNetworking", "~> 3.0"
----
s.dependency 'sqlite3'

dependency工程依赖的第三方库, 导入你的pod时,也会导入对应的依赖库。


  s.subspec 'standard' do |ss|
    ss.library = 'sqlite3'
    ss.source_files = 'src/fmdb/FM*.{h,m}'
    ss.exclude_files = 'src/fmdb.m'
    ss.header_dir = 'fmdb'
  end

  # use the built-in library version of sqlite3 with custom FTS tokenizer source files
  s.subspec 'FTS' do |ss|
    ss.source_files = 'src/extra/fts3/*.{h,m}'
    ss.dependency 'FMDB/standard'
  end

  # build the latest stable version of sqlite3
  s.subspec 'standalone' do |ss|
    ss.xcconfig = { 'OTHER_CFLAGS' => '$(inherited) -DFMDB_SQLITE_STANDALONE' }
    ss.dependency 'sqlite3'
    ss.source_files = 'src/fmdb/FM*.{h,m}'
    ss.exclude_files = 'src/fmdb.m'
    ss.header_dir = 'fmdb'
  end

为了让自己的Pod被导入时显示出良好的文件层划分,subspec是必须的。这个FMDB的写法
若subspec要依赖其它的subspec,则subspec的dependency后面接的不是目录路径,而是specA/specB这种spec关系

其他常见的几个坑, 组件化的坑:在私有Pod中使用主工程的framework

[iOS] CocoaPods - Podspec文件配置

最后放几个Github上常用的三方库,可以参考他们的写法

AFNetworking/AFNetworking.podspec

SDWebImage/SDWebImage.podspec

 MJRefresh/MJRefresh.podspec

jpush-react-native/JPush.podspec

fmdb/FMDB.podspec

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在开发Flutter插件时,有时候需要使用第三方库来实现一些功能,这时需要在Podspec文件中添加对第三方库的依赖描述。 以下是添加第三方库依赖的示例代码: ``` Pod::Spec.new do |s| s.name = '插件名称' s.version = '插件版本号' s.summary = '插件描述' s.homepage = '插件主页' s.license = '插件许可证' s.author = { '作者名称' => '作者邮箱' } s.source = { :git => '插件源代码仓库地址', :tag => '插件版本号' } s.dependency '库名称', '~> 版本号' # 插件依赖的第三方库 s.source_files = '插件源代码文件路径' # 插件的源代码文件 s.resource_bundles = { '插件资源文件名称' => ['插件资源文件路径'] } # 插件的资源文件 end ``` 其中,`dependency`方法用于添加依赖库的描述,第一个参数是库的名称,第二个参数是库的版本号。`~>`表示兼容某个版本号及以上的库。 当需要使用多个依赖库时,可以依次调用`dependency`方法添加多个依赖库的描述,如下所示: ``` Pod::Spec.new do |s| s.name = '插件名称' s.version = '插件版本号' s.summary = '插件描述' s.homepage = '插件主页' s.license = '插件许可证' s.author = { '作者名称' => '作者邮箱' } s.source = { :git => '插件源代码仓库地址', :tag => '插件版本号' } s.dependency '库1名称', '>= 版本号' # 插件依赖的第三方库1 s.dependency '库2名称', '~> 版本号' # 插件依赖的第三方库2 s.source_files = '插件源代码文件路径' # 插件的源代码文件 s.resource_bundles = { '插件资源文件名称' => ['插件资源文件路径'] } # 插件的资源文件 end ``` 需要注意的是,当使用第三方库时,需要将库的头文件和源文件一起打包到插件中,以便在编译插件时能够正确地链接库的代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值