建立CocoaPods私有源(1)

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)庫便可。

image.png

如果在Podfile里面聲明了use_frameworks!,CocoaPods會生成framework方式的庫(反之生成靜態(tài)庫.a),因為swift的項目需要使用framework方式導(dǎo)入第三方庫。

image.png

  • 不使用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的所有版本的索引文件

image.png

這個索引文件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文件,此文件包含了此項目的版本信息,作者信息,依賴信息,資源路徑等。

image.png

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.jsonAFNetworking.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'

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。