将集成的开源代码上传到Cocoapods管理

2017-03-29  本文已影响51人  Manba_小洛

1.前期工作

2.准备工作和配置相关信息

$ cd XXXFramework
$ pod spec create XXXFramework  
$ git add .  // 提交所有添加的文件
$ git commit -m "描述信息" // 提交修改
$ git tag '1.0.0'  // 为当前版本标记tag, 这个是一定要做的!!! 因为pod需要根据版本号确定引用
$ git push --tags // 提交当前标记的tag
$ git push origin master // push修改到远程仓库,git push 也可以
Pod::Spec.new do |s|
  s.name             = "XXXFramework"
  s.version          = "1.0.0"  // 这个一定要与当前版本的tag相对应
  s.summary          = "这里写简介信息"
  s.description      = <<-DESC
 这里写描述信息,并且尽量保证比简介信息要更多更全面,否则后面验证会有警告(虽然警告没有影响,但是我们尽量做到验证的时候没有警告)。
                       DESC
  s.homepage         = "github的项目地址"
  s.license          = 'MIT'
  s.author           = { "github的帐号" => "github帐号对应的邮箱" }
  s.source           = { :git => "github上面的对应工程的git地址(例如:https://github.com/xxxx/XXXFramework.git)", :tag => s.version }
  s.platform     = :ios
  s.ios.deployment_target = '8.0'
  # s.osx.deployment_target = '10.7'
  s.requires_arc = true

  #s.source_files = 'WZMarqueeView/*'
  # s.resources = 'Assets'

  # s.ios.exclude_files = 'Classes/osx'
  # s.osx.exclude_files = 'Classes/ios'
  # s.public_header_files = 'Classes/**/*.h'
  s.vendored_frameworks = "RoyFramework.framework" 
  s.frameworks = "Foundation", "UIKit"
end

ps: 这里面用不到的可以直接注释掉(#).这里对可能用到的配置进行说明

s.name  // 导入pod后的目录名
s.version // 当前版本号
s.license // 类型,这里直接填写MIT
s.author // 用户信息
s.source // 所引用的代码源地址
s.platform // 适用平台
s.ios.deployment_target // 最低的系统版本
s.requires_arc // 是否要求arc
s.prefix_header_file // 预编译头文件路径,将该文件的内容插入到pod的pch文件中
===重点====
s.source_files   // 将上传的代码文件,路径从.podspec开始,如果是开源的.h .m 文件,就需要写成路径/*.{h,.m}, 例如"Classes/**/*.{h,m}
s.resources // 资源文件,图片或者xib文件
s.vendored_frameworks // 本地最后自己打包的frameworks
s.frameworks // 指定需要使用的系统frameworks, 例如:UIKit, Foundation
s.preserve_paths // 本地自己导入的.a库
s.dependency //指定依赖,如果依赖的库不存在或者依赖库的版本不符合要求将会报错
s.libraries // 指定导入的库,比如sqlite3
s.weak_frameworkds // 弱链接,比如说一个项目同时兼容iOS和iOS7, 但某一个framework只有在iOS7上有,这时如果使用强连接,那么在iOS7上运行就会crash, 使用weak_frameworks可以便面这种情况

通配符说明

a{bb,bc}def.{h,m}表示四个文件abbdef.h abbdef.m abcdef.h abcdef.m
*.{h,m,mm}表示所有的.h .m .mm文件
Class/**/*.{h,m}表示Class目录下的所有.h .m文件

3.验证编写的 podspec 文件

$ pod spec lint
如果出现--allow-warnings的警告那么执行下面这句消除警告
$ pod spec lint --allow-warnings
如果出现错误信息,则按照提示进行修改
-> XXXFramework (1.0.0)  
XXXFramework passed validation.  
出现上面这个显示,则表示通过了验证,就可以进行下一步的操作

4.通过 trunk 上传 spec 到 cocoapods

$ pod trunk me
// 如果现实帐号信息则表示已经注册过就可以直接push 面的操作:例如
 - Name:     xxx
  - Email:    xxxabc123@qq.com
  - Since:    March 27th, 04:39
  - Pods:
    - xxxxxx
  - Sessions:
    - March 27th, 04:39 - August 2nd, 04:55. IP: 116.228.209.98
// 否则就需要注册trunk帐号
$ pod trunk register XXX@XXX.com '名字' --verbose
// 然后收到邮件之后点击进入邮件中的链接出现 ACE, YOU'RE SET UP 就表示注册成功
$ pod trunk push XXXFramework.podspec

5.验证

rm ~/Library/Caches/CocoaPods/search_index.json

重新搜索从远程拉取索引文件:

pod search XXXFramework

6.版本迭代和更新

上一篇 下一篇

猜你喜欢

热点阅读