CocoaPods 系列(三)—— 使用

添加 pods 到 Xcode 工程

开始之前请先做两件事情:

安装到现有工程

创建 Podfile 文件,添加依赖:

target 'MyApp' do
  pod 'AFNetworking', '~> 3.0'
  pod 'FBSDKCoreKit', '~> 4.9'
end
  • 在工程目录下执行 pod install
  • 打开并编译 MyApp.xcworkspace

创建一个新的工程并集成 CocoaPods

创建一个新的工程并集成 CocoaPods,步骤如下:

  • 创建一个普通的 Xcode 工程;
  • 打开终端,cd 到工程目录;
  • 创建 Podfile 文件,这可以通过执行 pod init 来完成;
  • 打开 Podfile 文件,第一行必须制定使用的平台和版本;
platform :ios, ‘9.0’
  • 你需要指定 Xcode 的 target。如果是 iOS App target 就是 工程的名称。通过target '$TARGET_NAME' do代表 target 的开始,end 表示结束;
  • 在 target 的范围内使用 pod '$PODNAME' 添加 pod
target 'MyApp' do
  pod 'ObjectiveSugar'
end
  • 保存 Podfile;
  • 执行 pod install;
  • 将工程通过 MyApp.xcworkspace打开.

集成已经存在的 workspace

集成 CocoaPods 到已经存在的 .workspace 工程,需要在 Podfile 中 ,targe 范围外,添加一行:

workspace 'MyWorkspace'

pod installpod update使用时机

很多人会疑惑 pod installpod update 应该在什么时候用,经常是在本应该用 pod install 的时候使用了 pod update

你可以在这里找到它们详细的说明。

是否应该将 Pods 目录加入版本控制

是否将 Pods 加入版本控制,需要看情况而定。官方建议把 Pods 目录加入版本控制,不要把它加入 .gitignore,不过最终还是看你自己决定:

加入版本控制的好处

  • 仓库克隆完毕,可以立即编译运行,即使没有安装 CocoaPods。不需要执行 pod install,也不用网络连接。
  • pod 对应的库总是可用的,即使 pod 的源码无法获取了。
  • 能够保证克隆下来的 pod 库同安装和编译它的人版本一致。

忽略版本控制的好处

  • git 仓库会占用的空间少。
  • 只要 Pod 源代码还在,总是能够通过 pod install 重新安装原先的版本。
  • 可以避免在合并分支的时候出现 Pod 源码版本不一致的冲突。

不管是否将 pods 目录加入版本库, PodfilePodfile.lock 是一定要加入版本控制的。

什么是 Podfile.lock ?

它会在第一次执行 pod install 的时候生成,并且跟踪已经安装的 pod 的版本。例如,假设 Podfile 中有如下依赖:

pod 'RestKit'

执行 pod install 会安装当前最新的版本,并生成 Podfile.lock 文件记录该版本号(比如说:RestKit 0.10.3)。之后在其它机器上,即使 RestKit有了新的版本,这个工程目录下执行 pod install 安装的仍旧是 0.10.3 版本。除非修改 Podfile 中指定的版本或者执行 pod update 否者 Podfile.lock 会保证 pods 的版本不变。

这里有一个 Google 介绍它是如何工作的视频 CocoaPods and Lockfiles (Route 85).

背后的实现

在 Xcode 中,可以直接查看 CocoaPods 的ruby 源代码

  1. 创建或者更新 workspace
  2. 添加你的工程到 workspace。
  3. 添加 CocoaPods 的静态库到 workspace。
  4. 添加 App-Pods.framework 到 targets => build phases => link with libraries
  5. 添加 CocoaPods 的 Xcode 配置文件到工程。
  6. 根据 CocoaPods 来修改 app target 配置
  7. 添加一个 build phase 脚本来将 pods 中的资源文件拷贝到 app bundle 中 ,在 build phase 的最后面添加 Copy Pods Resource
    1. Shell: /bin/sh
    2. ${SRCROOT}/Pods/PodsResources.sh

步骤3中如果工程中原本有静态库就直接跳过。

原文

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 项目组件化、平台化是技术公司的共同目标,越来越多的技术公司推崇使用pod管理第三方库以及私有组件,一方面使项目架构...
    swu_luo阅读 22,395评论 0 39
  • 一. CocoaPods的介绍 什么是CocoaPods?CocoaPods是一个负责管理iOS项目中第三方开源库...
    辉712阅读 4,019评论 0 7
  • Ruby 安装 要安装cocospods 首先需要安装ruby,可以先安装xcode,再安装macport ,最后...
    山天大畜阅读 1,918评论 0 1
  • CocoaPods 是什么? CocoaPods 是一个负责管理 iOS 项目中第三方开源库的工具。CocoaPo...
    朝洋阅读 25,783评论 3 50
  • 文/余福海 9月1日,美国华纳公司出品的战争大剧《敦刻尔克》登陆中国影院,英国军民上下齐心,共赴国难的英勇气概给人...
    余福海阅读 801评论 0 0