記得我剛開始做iOS開發的時候,是沒有項目依賴管理工具。當需要引入第三方庫的時候是相當麻煩的,不是直接拷貝庫近來,就是添加依賴工程,直到CocoaPods出來才改變這個狀況。項目依賴管理不是CocoaPods首創,在很多其他工程開發當中早已經出現,甚至成為了開發的標配,盡管如此,CocoaPods依然是對iOS/Mac開發做出了巨大的貢獻,在此為CocoaPods做出貢獻的人表示感謝。
CocoaPods功能不算太強大,但大部分時候足夠好用,僅僅是最基本的樣例配置,就可以滿足你項目的大部分需求,但了解更多的一一些的特性,會讓你更得心應手。
指定源
CocoaPods支持私有 Spec 倉庫的,我們可以建立自己的源,也可以使用非官方的源,只要是符合規定的都可以指定。
source 'https://github.com/artsy/Specs.git' source 'https://github.com/CocoaPods/Specs.git'
抑制警告
inhibit_warnings參數能夠有效的抑制CocoaPods引入的第三方代碼庫產生的warning。
可以全部指定。
inhibit_all_warnings!
也可以針對指定。
pod 'ReactiveCocoa', '~> 2.4', :inhibit_warnings => true
使用git的HEAD指向的分支
pod 'ISO8601DateFormatter', :head
使用 master 分支
pod 'ARAnalytics/Mixpanel', :git => 'https://github.com/orta/ARAnalytics.git'
指定branch
pod 'Reachability', :git => 'https://github.com/ashfurrow/Reachability.git', :branch => 'frameworks'
指定tag
pod 'AFNetworking', :git => 'https://github.com/gowalla/AFNetworking.git', :tag => '0.7.0'
指定commit
pod 'ARTiledImageView', :git => 'https://github.com/dblockARTiledImageView', :commit => '1a31b864d1d56b1aaed0816c10bb55cf2e078bb8'
使用子庫
可以這樣
pod 'QueryKit/Attribute'
也可以這樣指定多個子庫
pod 'QueryKit', :subspecs => ['Attribute', 'QuerySet']
使用本地代碼
通過:path可以指定本地代碼,不過需要確保目錄包含podspec文件。
pod 'AFNetworking', :path => '~/Documents/AFNetworking'
指定target的依賴庫
target :ZipApp do pod 'SSZipArchive' end
排除taget
target 'Artsy Tests', :exclusive => true do pod 'FBSnapshotTestCase', '1.4' end
指定xcodeproj
默認會使用Podfile文件同級目錄下第一個xcodeproj,但也可以指定
xcodeproj 'MyProject' target :test do # This Pods library links with a target in another project. xcodeproj 'TestProject' end
指定連接的target
如果不顯式指定連接的target,Pods會默認連接project的第一個target。如果需要,可以使用link_with指定連接一個或多個target
link_with 'MyApp', 'MyOtherApp'
指定依賴庫的配置文件
pod 'PonyDebugger', :configuration => ['Release']
指定target的配置文件
xcodeproj 'TestProject', 'Mac App Store' => :release, 'Test' => :debug
使用Dynamic Frameworks代替Static Libraries
通過標志use_frameworks!就可知開啟這個功能。如果需要使用Swift的庫,就必須加上這個標志了。
加快pod install/update 速度
使用CocoaPods來添加第三方類庫,無論是執行pod install還是pod updat很多時候都卡在了Analyzing dependencies不動,這是更新本地的pod spec所以文件導致的。通過--no-repo-update標志可以不更新本地pod spec索引。當然首次install不應該添加這個標志,後續修改Podfile的時候可以適當使用,加快pod速度。
pod install --no-repo-update pod update --no-repo-update
輸出詳細日志
pod update --verbose
XCode的Cocoapods插件
cocoapods-xcode-plugin是一個XCode的插件,讓你方便操作Cocoapods,那是相當好用的一個插件。
END
不才水平有欠,如有錯誤,請斧正。