CocoaPods的安裝與使用

CocoaPods是應用級依賴項管理器(dependency manager),用于管理Objective-C、Swift語言應用的依賴項。由Eloy Durán 和 Fabio Pelosin于2011年開發完成。

1. 安裝CocoaPods

CocoaPods是使用Ruby語言編寫的,macOS系統默認安裝了Ruby。CocoaPods建議使用默認的Ruby安裝CocoaPods,除非你對Ruby有所了解。

使用如下命令安裝CocoaPods:

$ sudo gem install cocoapods

使用系統自帶Ruby安裝CocoaPods時,需要使用sudo權限。

輸入上面命令后,命令行提示如下:

Fetching: concurrent-ruby-1.0.5.gem (100%)
Successfully installed concurrent-ruby-1.0.5
Fetching: i18n-0.9.1.gem (100%)
Successfully installed i18n-0.9.1
...
Installing ri documentation for cocoapods-1.3.1
Done installing documentation for concurrent-ruby, i18n, thread_safe, tzinfo, activesupport, nap, fuzzy_match, cocoapods-core, claide, cocoapods-deintegrate, cocoapods-downloader, cocoapods-plugins, cocoapods-search, cocoapods-stats, netrc, cocoapods-trunk, cocoapods-try, molinillo, colored2, nanaimo, xcodeproj, escape, fourflusher, gh_inspector, ruby-macho, cocoapods after 31 seconds
26 gems installed

使用如下命令查看CocoaPods版本:

$ gem list --local | grep cocoapods
cocoapods (1.3.1)
cocoapods-core (1.3.1)
cocoapods-deintegrate (1.0.1)
cocoapods-downloader (1.1.3)
cocoapods-plugins (1.0.0)
cocoapods-search (1.0.0)
cocoapods-stats (1.0.0)
cocoapods-trunk (1.3.0)
cocoapods-try (1.1.0)

可以看到cocoapods版本為1.3.1,同時也可以看到其它部分版本。

默認安裝的CocoaPods為正式版,使用gem install cocoapods --pre命令安裝測試版CocoaPods,使用gem install cocoapods -v x.y.z 命令安裝指定版本CocoaPods。

2. 更新CocoaPods

只需要再次安裝,就可以將CocoaPods升級到最新版:

$ [sudo] gem install cocoapods

如果安裝CocoaPods時使用了sudo權限,更新時也需要sudo權限。

如果CocoaPods有了新版本,在你使用pod命令時會得到CocoaPods X.X.X is now available, please update.的提示信息。

3. 移除低版本CocoaPods

CocoaPods更新到新版本后,低版本的CocoaPods并不會被自動移除。如下所示:

$ gem list --local | grep cocoapods
cocoapods (1.3.1, 1.1.0)
cocoapods-core (1.3.1, 1.1.0)
cocoapods-deintegrate (1.0.1)
cocoapods-downloader (1.1.3)
cocoapods-plugins (1.0.0)
cocoapods-search (1.0.0)
cocoapods-stats (1.0.0)
cocoapods-trunk (1.3.0)
cocoapods-try (1.1.0)

使用如下命令移除指定版本CocoaPods:

$ gem uninstall cocoapods -v 1.1.0
Successfully uninstalled cocoapods-1.1.0
$ gem uninstall cocoapods-core -v 1.1.0
Successfully uninstalled cocoapods-core-1.1.0

// 查看cocoapods版本。
$ gem list --local | grep cocoapods
cocoapods (1.3.1)
cocoapods-core (1.3.1)
cocoapods-deintegrate (1.0.1)
cocoapods-downloader (1.1.3)
cocoapods-plugins (1.0.0)
cocoapods-search (1.0.0)
cocoapods-stats (1.0.0)
cocoapods-trunk (1.3.0)
cocoapods-try (1.1.0)

4. 管理第三方庫

4.1 創建Podfile文件

CocoaPods中Podfile 文件用于列出要在項目中使用的庫,可以使用以下兩種方式創建Podfile文件:

  • 在項目目錄中創建一個名為Podfile的空文本文件。
  • 將Terminal定位到項目目錄,輸入pod init命令,CocoaPods會自動創建Podfile文件,并會自動初始化一些必要代碼。推薦使用pod init命令創建Podfile文件。

使用pod init命令創建的Podfile文件內容如下:

# Uncomment the next line to define a global platform for your project
# platform :ios, '9.0'

target 'MyApp' do
  # Uncomment the next line if you're using Swift or would like to use dynamic frameworks
  # use_frameworks!

  # Pods for MyApp

  target 'MyAppTests' do
    inherit! :search_paths
    # Pods for testing
  end

end                                                                          

4.2 列出所需第三方庫

Podfile文件內容可以非常簡單,如下所示:

target 'MyApp` do
  pod 'Mantle'
end

下面使用vim編輯Podfile文件,添加MantleReactiveObjC第三方庫:

# 這里Pod支持iOS系統,還可以支持osx。如果沒有說明支持的系統,默認支持所有系統。
platform :ios, '9.0'

target 'MyApp' do
  pod 'Mantle'
  pod 'ReactiveObjC', '~> 3.1.0'
  
  target 'MyAppTests' do
    inherit! :search_paths
    # Pods for testing
  end

end

添加第三方庫時,如果沒有指定版本,則默認使用最新正式版。另外,使用如下命令指定版本:

// 使用2.1.0版本的Mantle
pod 'Mantle', '2.1.0'

除不使用版本號、固定版本號,還可以使用邏輯符指定版本號。

  • '> 0.2':比0.2高的任何版本。
  • >= 0.2:大于等于0.2版本。
  • < 0.2:小于0.2的版本。
  • ~> 0.6.48':大于等于0.6.48版本,但小于0.7版本。
  • '~> 0.6':大于等于0.6版本,但小于1.0版本。
  • '~> 1':主版本號大于等于1

4.3 添加第三方庫

使用pod install命令添加第三方庫:

$ pod install
Analyzing dependencies
Downloading dependencies
Installing Mantle (2.1.0)
Installing ReactiveObjC (3.1.0)
Generating Pods project
Integrating client project

[!] Please close any current Xcode sessions and use `MyApp.xcworkspace` for this project from now on.
Sending stats
Pod installation complete! There are 2 dependencies from the Podfile and 2 total pods installed.

根據終端提示,如果想要使用剛添加的第三方庫,必須打開MyApp.xcworkspace,而非之前的MyApp.xcodeProj

4.4 導入第三方庫

CocoaPods創建Mantlepod工程,并添加到你的workspace。因此,當你導入Mantle時,是從workspace的其它工程導入,需要使用尖括號(< >)而非雙引號(“ ”)。

#import <Mantle/Mantle.h>

5. pod install VS pod update

剛接觸CocoaPods時,很多人會誤以為pod install用在初次設置工程時,之后使用pod update,事實并非如此。

  • 使用pod install命令在project中添加新的pods。即使之前已經使用過pod install命令,在添加、移除pods時,依然使用pod install命令。
  • 只有需要把pods更新到新版本時,使用pod update [PODNAME]命令。

5.1 pod install

第一次為project添加pods,編輯Podfile文件以添加、更新、移除pods,均使用pod install命令。

  • 每次運行pod install命令時,CocoaPods會把添加的pod版本信息寫入Podfile.lock文件,Podfile.lock文件跟蹤已安裝pod版本信息,并鎖定到當前版本。
  • 當運行pod install命令時,CocoaPods只處理未在Podfile.lock文件中列出的依賴項。
    • 對于Podfile.lock文件中列出的pods,CocoaPods直接下載Podfile.lock文件中列出的版本,不會嘗試查找新版本。
    • 對于未在Podfile.lock文件中列出的pods,CocoaPods會根據Podfile文件添加pods。

5.2 pod outdated

當運行pod outdated命令時,CocoaPods會查找Podfile.lock中所有pods,并列出更新版本的pods。也就是說,運行pod update [PODNAME]命令時,如果新版本符合Podfile的描述,則會更新pod到新版本。

$ pod outdated
Updating spec repo `master`
  $ /usr/local/bin/git -C /Users/ad/.cocoapods/repos/master fetch origin
  --progress
  remote: Counting objects: 45, done.        
  remote: Compressing objects: 100% (40/40), done.        
  remote: Total 45 (delta 27), reused 0 (delta 0), pack-reused 0        
  From https://github.com/CocoaPods/Specs
     f7d947da03c..a14b55af97b  master     -> origin/master
  $ /usr/local/bin/git -C /Users/ad/.cocoapods/repos/master rev-parse
  --abbrev-ref HEAD
  master
  $ /usr/local/bin/git -C /Users/ad/.cocoapods/repos/master reset --hard
  origin/master
  HEAD is now at a14b55af97b [Add] Waterpurifier 1.0.4

CocoaPods 1.4.0.rc.1 is available.
To update use: `gem install cocoapods --pre`
[!] This is a test version we'd love you to try.

For more information, see https://blog.cocoapods.org and the CHANGELOG for this version at https://github.com/CocoaPods/CocoaPods/releases/tag/1.4.0.rc.1

Analyzing dependencies
The following pod updates are available:
- Mantle 1.4.1 -> 1.4.1 (latest version 2.1.0)

5.3 pod update

運行pod update [PODNAME]命令時,Cocoapods會查找[PODNAME]的新版本,如果新版本同時滿足Podfile 文件對版本描述,則會更新pod。

如果運行pod update命令時不添加pod名稱,則會查找所有pods的新版本,并嘗試更新。

6. 查找第三方庫 pod search

Podfile文件中第三方庫名稱區分大小寫,寫錯后install第三方庫時會提示語法錯誤(syntax error)。為避免出錯,可以在添加之前先查找對應庫。

在Terminal中輸入pod search [PODNAME]即可進行查找,查找時不區分大小寫。可以配合其它可選項進行檢索,如—simple只查找pod名稱,—stats顯示GitHub中watch fork數據。

$ pod search --simple --stats AFNetworking
-> AFNetworking (3.1.0)
   A delightful iOS and OS X networking framework.
   pod 'AFNetworking', '~> 3.1.0'
   - Homepage: https://github.com/AFNetworking/AFNetworking
   - Source:   https://github.com/AFNetworking/AFNetworking.git
   - Versions: 3.1.0, 3.0.4, 3.0.3, 3.0.2, 3.0.1, 3.0.0, 3.0.0-beta.3,
   3.0.0-beta.2, 3.0.0-beta.1, 2.6.3, 2.6.2, 2.6.1, 2.6.0, 2.5.4, 2.5.3, 2.5.2,
   2.5.1, 2.5.0, 2.4.1, 2.4.0, 2.3.1, 2.3.0, 2.2.4, 2.2.3, 2.2.2, 2.2.1, 2.2.0,
   2.1.0, 2.0.3, 2.0.2, 2.0.1, 2.0.0, 2.0.0-RC3, 2.0.0-RC2, 2.0.0-RC1, 1.3.4,
   1.3.3, 1.3.2, 1.3.1, 1.3.0, 1.2.1, 1.2.0, 1.1.0, 1.0.1, 1.0, 1.0RC3, 1.0RC2,
   1.0RC1, 0.10.1, 0.10.0, 0.9.2, 0.9.1, 0.9.0, 0.7.0, 0.5.1 [master repo]
   - Author:   Mattt Thompson
   - License:  MIT
   - Platform: iOS 7.0 - macOS 10.9 - tvOS 9.0 - watchOS 2.0
   - Stars:    30058
   - Forks:    9386
   - Subspecs:
     - AFNetworking/Serialization (3.1.0)
     - AFNetworking/Security (3.1.0)
     - AFNetworking/Reachability (3.1.0)
     - AFNetworking/NSURLSession (3.1.0)
     - AFNetworking/UIKit (3.1.0)

另外,也可以在CocoaPods官網進行搜索。

總結

由于Swift不支持靜態庫(static library),在Swift中使用時必須使用framework。

target 'MyApp` do
  use_frameworks!
  pod 'MJRefresh`, '~> 3.1.15`
end

有時添加的第三庫會有一些警告信息,通過在Podfile添加以下命令可以隱藏第三方庫中的警告信息。

platform :ios, '9.0'
# 隱藏所有警告
inhibit_all_warnings!

target 'MyApp' do
  pod 'Mantle', '1.4.1'
  # 不要隱藏ReactiveObjC的警告,也可以用此方法只隱藏指定pod警告。
  pod 'ReactiveObjC', '~> 3.1.0', :inhibit_warnings => false

end

另外,關于是否將Pods文件加入版本控制,可以根據下面的利弊自行決定:

  • Pods文件加入版本控制:
    • 可以在clone倉庫后立即開始工作,不需要pod install
    • 可以保證每人都使用相同版本。
    • 即使原始pod已經移除也可以繼續使用。
  • Pods文件排除在版本控制系統外:
    • 使得倉庫更小。
    • 合并分支時不會出現不同Pod版本間沖突。

但需要注意的是,一定要把Podfile文件和Podfile.lock文件加入版本控制。

最后,CocoaPods除了將開源庫添加到你的項目外,還可以創建公開、私有pod,具體方法可以查看使用CocoaPods創建公開、私有pod這篇文章。

歡迎更多指正:https://github.com/pro648/tips/wiki

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,362評論 6 544
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,577評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,486評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,852評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,600評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,944評論 1 328
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,944評論 3 447
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 43,108評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,652評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,385評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,616評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,111評論 5 364
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,798評論 3 350
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,205評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,537評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,334評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,570評論 2 379

推薦閱讀更多精彩內容