CocoaPods簡介
CocoaPods是Swift和Objective-C 項目的依賴管理器。它擁有超過61000個第三方庫,超過300萬個應(yīng)用程序都使用CocoaPods來管理第三方庫。
CocoaPods使用
新建一個普通的xcode項目時,如果需要使用CocoaPods管理第三方庫,需要新建一個Podfile文件,當(dāng)你執(zhí)行pod install
之后,CocoaPods 會生成一個名為Podfile.lock的文件,Podfile.lock 是Podfile文件序列化的文件,記錄了各個第三方庫的版本和和第三方庫的依賴。
如果存在Podfile.lock文件,那么每次執(zhí)行pod install
,都是從Podfile.lock文件來獲取第三方庫的版本,除非執(zhí)行pod update
才會更新Podfile.lock文件。
CocoaPods 在執(zhí)行 pod install 和 pod update 時,會更新一次 Specs 索引倉庫。使用以下命令,強制不更新索引,
pod install --no-repo-update
pod update --no-repo-update
use_frameworks!
每次執(zhí)行pod install時,CocoaPods 項目最終會編譯成一個名為 libPods-XXX.a
的文件,主項目只需要依賴這個靜態(tài)庫便可。
如果在Podfile里面聲明了use_frameworks!
,CocoaPods會生成framework方式的庫(反之生成靜態(tài)庫.a),因為swift的項目需要使用framework方式導(dǎo)入第三方庫。
- 不使用
use_frameworks!
-> static libraries 方式 -> 生成.a文件 -
use_frameworks!
-> dynamic frameworks 方式 -> 生成.framework文件
如果第三方庫包含資源文件,CocoaPods 提供了一個名為 Pods-XXX-resources.sh
的 bash 腳本,該腳本在每次項目編譯的時候都會執(zhí)行,將第三方庫的資源文件復(fù)制到主工程的目標目錄中。
如果需要編輯第三方庫的一些依賴和編譯參數(shù),可以修改相對應(yīng)的第三方庫的XXX.xcconfig
文件。
CocoaPods 管理第三方庫
在電腦上安裝CocoaPods后,可以在以下路徑~/.cocoapods/repos/master/
看到CocoaPods相關(guān)的文件。簡單來說,其實CocoaPods也是一個托管在GitHub上的一個普通的Git項目。在master目錄下有一個Specs
文件夾,這個文件夾包含了CocoaPods所管理的所有第三方庫的索引。
我們可以在Specs
文件夾找到被CocoaPods索引的所有第三方庫的相關(guān)信息。
如AFNetworking的所有版本的索引文件
這個索引文件
AFNetworking.podspec.json
是一個普通的json文件,部分內(nèi)容如下
{
"name": "AFNetworking",
"version": "3.2.1",
"license": "MIT",
"summary": "A delightful iOS and OS X networking framework.",
"homepage": "https://github.com/AFNetworking/AFNetworking",
"social_media_url": "https://twitter.com/AFNetworking",
"authors": {
"Mattt Thompson": "m@mattt.me"
},
"source": {
"git": "https://github.com/AFNetworking/AFNetworking.git",
"tag": "3.2.1",
"submodules": true
},
"requires_arc": true,
"public_header_files": "AFNetworking/AFNetworking.h",
"source_files": "AFNetworking/AFNetworking.h",
"prefix_header_contents": "#ifndef TARGET_OS_IOS\n #define TARGET_OS_IOS TARGET_OS_IPHONE\n#endif\n\n#ifndef TARGET_OS_WATCH\n #define TARGET_OS_WATCH 0\n#endif\n\n#ifndef TARGET_OS_TV\n #define TARGET_OS_TV 0\n#endif",
"platforms": {
"ios": "7.0",
"osx": "10.9",
"watchos": "2.0",
"tvos": "9.0"
},
發(fā)布在GitHub上的項目,如果想加入CocoaPods的索引庫里面,需要在根目錄添加一個.podspec
文件,此文件包含了此項目的版本信息,作者信息,依賴信息,資源路徑等。
AFNetworking.podspec文件部分如下
Pod::Spec.new do |s|
s.name = 'AFNetworking'
s.version = '3.2.1'
s.license = 'MIT'
s.summary = 'A delightful iOS and OS X networking framework.'
s.homepage = 'https://github.com/AFNetworking/AFNetworking'
s.social_media_url = 'https://twitter.com/AFNetworking'
s.authors = { 'Mattt Thompson' => 'm@mattt.me' }
s.source = { :git => 'https://github.com/AFNetworking/AFNetworking.git', :tag => s.version, :submodules => true }
s.requires_arc = true
s.public_header_files = 'AFNetworking/AFNetworking.h'
s.source_files = 'AFNetworking/AFNetworking.h'
# 省略
CocoaPods的索引文件AFNetworking.podspec.json
和AFNetworking.podspec
很類似。其實兩者是可以轉(zhuǎn)換的,在項目的根目錄下,執(zhí)行以下命令便可。
$ pod ipc spec AFNetworking.podspec >> AFNetworking.podspec.json
對于一些沒有寫.podspec
文件的GitHub開源庫,可以也可以在CocoaPods中導(dǎo)入,在Podfile文件中如下編寫便可
直接導(dǎo)入
pod 'RNSVG', :git =>'[https://github.com/magicismight/react-native-svg.git](https://github.com/magicismight/react-native-svg.git)', :tag => '9.2.4'
一般導(dǎo)入
pod 'libwebp', '0.6.0'