本文是对瓜神的Cocoapos历险记系列中问题的解答,用来记录学习过程~
1.0版本管理工具及 Ruby 工具链环境
- PM 是如何进行依赖库的版本管理?
答:
- PM 工具基本围绕这个两个文件来现实包管理:
- 描述文件:声明了项目中存在哪些依赖,版本限制;
- 锁存文件(Lock 文件):- 记录了依赖包最后一次更新时的全版本列表。
- Ruby 和 RVM/rbenv 之间的关系是什么?
答
RVM
[11] 和rbenv
[12] 都是管理多个 Ruby 环境的工具,它们都能提供不同版本的 Ruby 环境管理和切换。
- Gem、Bundler 和 CocaPods 之间的关系是什么?>答:
- Gem:用ruby编写的工具或依赖;
- Bundler[15] 是管理 Gem 依赖的工具,可以隔离不同项目中 Gem 的版本和依赖环境的差异,也是一个 Gem。
- CocoaPods 其实是 iOS 版的 RubyGems + Bundler 组合
- 如何通过 Bundler 来管理工程中的 Gem 环境?
答:
- 初始化Bundle环境,生成Gemfile文件,在文件列出gem列表和版本号
5.如何锁死工程内部的 CocoaPods 版本?
答:
- 在 Gemfile 中声明使用的 CocoaPods 版本并安装
2.0 整体把握 CocoaPods 核心组件
- 简单概述 CocoaPods 的核心模块?答:
- CLAide:命令解析器,如解析pod install、pod update
- cocoapods-core :用于 CocoaPods 中模板文件的解析,包括 Podfile、.podspec,以及所有的 .lock 文件中特殊的 YAML 文件。
- cocoapods-downloader:是用于下载源码的小工具,它支持各种类型的版本管理工具,包括 HTTP / SVN / Git / Mercurial。它可以提供 tags、commites,revisions,branches 以及 zips 文件的下载和解压缩操作。
- Molinillo:是 CocoaPods 对于依赖仲裁算法的封装,它是一个具有前向检查的回溯算法。不仅在 Pods 中,Bundler 和 RubyGems 也是使用的这一套仲裁算法。
- Xcodeproj :可通过 Ruby 来操作 Xcode 项目的创建和编辑等。可友好的支持 Xcode 项目的脚本管理和 libraries 构建,以及 Xcode 工作空间 (.xcworkspace) 和配置文件 .xcconfig 的管理。
- cocoapods-plugins:插件管理功能,其中有 pod plugin 全套命令,支持对于 CocoaPods 插件的列表一览(list)、搜索(search)、创建(create)功能。
- pod 命令是如何找到并启动 CocoaPods 程序的? > 答:
- 通过
/usr/local/bin/pod
脚本文件,调用Gem.activate_bin_path 和 Gem.bin_path 用于找到 CocoaPods 的安装目录 cocoapods/bin,最终加载该目录下的 /pod 文件- 再通过 eval[8] 的手段调起我们需要的 CocoaPods 工程
- 通过调用 Pod::Command.run(ARGV),实例化了一个 CLAide::Command 对象,开始我们的 CLAide 命令解析阶段
- 简述 pod install 流程?> 答:
- 环境准备
- 解析依赖冲突
- 下载依赖
- 验证target
- 生成工程文件
- 写入依赖
- 结束回调
- resolve_dependencies 阶段中的 pre_download 是为了解决什么问题?> 答:
- 主要是解决当我们在通过 Git 地址引入的 Pod 仓库的情况下,系统无法从默认的 Source 拿到对应的 Spec,需要直接访问我们的 Git 地址下载仓库的 zip 包,并取出对应的 podspec 文件,从而进行对比分析。
- validate_targets 都做了哪些校验工作?> 答:
- 验证是否有重名的 framework
- 验证动态库中是否有静态链接库。此时如果项目的 Podfile 设置了 use_framework! 以动态链接方式打包的时,则会触发该错误。
- 确保 Swift Pod 的 Swift 版本正确配置且互相兼容的。
- 检测 Swift 库的依赖库是否支持了 module,这里的 module 主要是针对 Objective-C 库而言。
- 检测是否所有的 Pod Target 中版本一致性问题。