CocoaPods 原理分享及遇到的问题改进

2022-12-01,,,

cocoapods 原理分享及问题阐述

    cocoapods 管理私有工程,需要两个git 仓库,

    repo 仓库,保存podspec 文件,告诉我们项目从哪来,
    项目 仓库,保存工程文件,告诉我们引用的项目是什么
    CocoaPods是用ruby写的,并由若干个ruby包(gems)构成。在解析整合的过程中,最终要的几个gems分别是:
    CocoaPods/CocoaPods、

    这是一个面向用户的组件,每当执行一个pod命令时,这个组件都将被激活。该组件包括了所有使用CocoaPods涉及到的功能,并且还能通过调用左右其他的gems来执行任务。
    CocoaPods/Core
    Core组件提供支持与CocoaPods相关文件的处理,文件主要是Podfile和podspecs。

    podfile 用于定义项目中所需要使用的第三方库。
    podspec 描述了一个库是怎样被添加到工程中的。它支持的功能有:列出源文件、framework、编译选项和某个库所需要的依赖等
    CocoaPods/Xcodeproj。
    这个gem组件负责所有工程文件的整合。它能够对创建修改xcodeproj 和 .xworkspace 文件。它也可以作为一个单独的gem包使用。如果你想要写一个脚本来方便的修改工程文件,那么可以使用这个gem。
    pod 常用命令
    pod install

    这个是第一次在工程里面使用pods的时候使用,并且,也是每次你编辑你的Podfile(添加、移除、更新)的时候使用。

    每次运行pod install命令的时候,在下载、安装新的库的同时,也会把你安装的每个库的版本都写在了Podfile.lock文件里面。这个文件记录你每个安装库的版本号,并且锁定了这些版本。

    当你使用pod install它只解决了pods里面,但不在Podfile.lock文件里面的那些库之间的依赖。对于在Podfile.lock里面所列出的那些库,会下载在Podfile.lock里面明确的版本,并不会去检查是否该库有新的版本。对于还不在Podfile.lock里面的库,会找到Podfile里面描述对应版本(例如:pod "MyPod", "~>1.2")。
    一句话总结
    如果没有 podfile.lock,pod install 会依据podfile生成库和podfile.lock;
    如果原有 podfile.lock,pod install 依据podfile.lock生成库,对于不在podfile.lock但在podfile中的库会升级到满足podfile的最新版本,同时更新podfile.lock
    pod outdated:
    当你运行pod outdated命令,CocoaPods会列出那些所有较Podfile.lock里面有新版本的库(那些当前被安装着的库的版本)。这个意思就是,如果你运行pod update PODNAME,如果这个库有新的版本,并且新版本仍然符合在Podfile里的限制,它就会被更新。
    pod update

    当你运行 pod update PODNAME 命令时,CocoaPods会帮你更新到这个库的新版本,而不需要考虑Podfile.lock里面的限制,它会更新到这个库尽可能的新版本,只要符合Podfile里面的版本限制。

    如果你运行pod update,后面没有跟库的名字,CocoaPods就会更新每一个Podfile里面的库到尽可能的最新版本。此时会生化新的podfile.lock文件
    一句话总结:pod update 依据podfile文件更新库和podfile.lock
    pod update的执行过程大概分五步
    resolve_dependencies,又简单的分为两步

    update repo
    解析podfile
    download_dependencies (下载podfile中依赖以及其间接依赖)
    generate_pods_project (即生成dependency在Pods工程中的target,以及写pod file.lock等文件)
    integrate_targets
    peform_post_install_actions
    具体的时间消耗如下所示:
    使用过程中遇到的问题:
    为什么我们在子工程中增加删除文件,其他人必须pod update 一下,才能顺利编译?

    这是因为我们采用了git + cocoapods的管理方式,git 负责管源文件, 通过git pull 来同步远程代码, 而cocoapods 通过pod update/install 会生成pod.xcworkspace来管理这些文件的引用,所以我们通过git pull 实现了文件的拉取(增删改),但是没有通过pod update 来更新pod.xcworkspace的文件引用(增删),所以就会找不到编译报错
    如何减少子工程中增删文件,其他人必须pod update 才能顺利编译造成的时间开销?
    由于我们只是改了本地的私有podSepc引用,其他的pods依赖依然没有发生变化,也就是说我们没有必要再进行分析依赖下载依赖,步骤,如果我们可以直接 generate_pods_projec重新建立文件引用,就好了;更或者只是增加文件install_file_reference这一步就好
    我们可以通过读 CocoaPods/Xcodeproj中的源码,进行仿写修改来看看能不能实现以上功能。

CocoaPods 原理分享及遇到的问题改进的相关教程结束。

《CocoaPods 原理分享及遇到的问题改进.doc》

下载本文的Word格式文档,以方便收藏与打印。