一粪躬、什么是CocoaPods
每種語言發(fā)展到一個階段,就會出現(xiàn)相應(yīng)的依賴管理工具贯要,例如 Java 語言的 Maven,nodejs 的 npm椭住。隨著 iOS 開發(fā)者的增多崇渗,業(yè)界也出現(xiàn)了為 iOS 程序提供依賴管理的工具,它的名字叫做:CocoaPods京郑。
CocoaPods項(xiàng)目的源碼 在 Github 上管理宅广。該項(xiàng)目開始于 2011 年 8 月 12 日,經(jīng)過多年發(fā)展傻挂,現(xiàn)在已經(jīng)成為 iOS 開發(fā)事實(shí)上的依賴管理標(biāo)準(zhǔn)工具乘碑。開發(fā) iOS 項(xiàng)目不可避免地要使用第三方開源庫,CocoaPods 的出現(xiàn)使得我們可以節(jié)省設(shè)置和更新第三方開源庫的時間金拒。
二兽肤、為什么要使用CocoaPods
在使用CocoaPods之前,開發(fā)項(xiàng)目需要用到第三方開源庫的時候绪抛,我們需要
1.把開源庫的源代碼復(fù)制到項(xiàng)目中
2.添加一些依賴框架和動態(tài)庫
3.設(shè)置-ObjC资铡,-fno-objc-arc等參數(shù)
4.管理他們的更新
在使用CocoaPods后,我們只需要把用到的開源庫放到一個名為Podfile的文件中幢码,然后執(zhí)行pod install就可以了笤休,Cocoapods就會自動將這些第三方開源庫的源碼下載下來,并且為我們的工程設(shè)置好響應(yīng)的系統(tǒng)依賴和編譯參數(shù)症副。
三店雅、CocoaPods的原理
CocoaPods的原理是將所有的依賴庫都放到另一個名為Pods的項(xiàng)目中,然后讓主項(xiàng)目依賴Pods項(xiàng)目贞铣,這樣闹啦,源碼管理工作都從主項(xiàng)目移到了Pods項(xiàng)目中。Pods項(xiàng)目最終會編譯成一個名為libPods.a的文件辕坝,主項(xiàng)目只需要依賴這個.a文件即可窍奋。
四、CocoaPods的安裝
打開終端酱畅,
1.設(shè)置ruby的軟件源
gem sources -l #(查看當(dāng)前ruby的源)
gem sources --remove https://rubygems.org/ #(移除當(dāng)前ruby的源)
https://gems.ruby-china.com/ #(設(shè)置當(dāng)前ruby的源為我天朝的)
gem sources -l #(再次查看當(dāng)前ruby的源)
如果Terminal輸出:
*** CURRENT SOURCES ***
https://gems.ruby-china.com/
就證明ruby的軟件源已經(jīng)設(shè)置OK了琳袄。
2.設(shè)置gem為最新版本
如果gem太老,可以嘗試用如下命令升級gem:
在Terminal輸入以下命令:
sudo gem update --system
升級成功后會提示: Latest version currently installed. Aborting.
3.執(zhí)行安裝CocoaPods命令
sudo gem install? cocoapods
如果執(zhí)行上述命令行時出錯:
ERROR:? While executing gem ... (Errno::EPERM)
Operation not permitted - /usr/bin/pod
執(zhí)行以下命令行
sudo gem install -n /usr/local/bin cocoapods
pod setup
值得注意的是纺酸,在pod setup的時候窖逗,會輸出Setting up CocoaPods master repo
但是這個階段會等很長時間,這步其實(shí)是 Cocoapods 在將它的信息下載到 ~/.cocoapods目錄下餐蔬,
警告??:
如果這個過程太久并且沒有出現(xiàn)下載進(jìn)度及網(wǎng)速的話碎紊,是因?yàn)樵趫?zhí)行pod setup的時候master這個庫沒成功在张,所以就算移除鏡像重新安裝的話,默認(rèn)是從master庫里獲取矮慕,導(dǎo)致安裝不成功帮匾,解決辦法是移除master庫,重新創(chuàng)建
pod repo upadte --verbose
rm -rf ~/.cocoapods/repos/master
然后再執(zhí)行pod setup
安裝成功后,你會看到:Setup completed
4.cocoapods使用
cd到工程根目錄
vim Podfile
直接輸入需要添加的庫
pod install
如果pod install被墻的話痴鳄,改用
pod install --verbose --no-repo-update
附:如何使用CocoaPods的鏡像索引:
所有項(xiàng)目的Podspec文件都托管在https://github.com/CocoaPods/Specs,
第一次執(zhí)行pod setup時,CocoaPods會將這些podspec索引文件更新到本地的~/.cocoapods目錄下,
這個索引文件比較大,所以第一次更新時非常慢.
友好人士在國內(nèi)的服務(wù)器建立了Cocoapods索引庫的鏡像,
所以執(zhí)行索引跟新操作時候會快很多.具體操作方法如下:
pod repo remove master
pod repo add master https://gitcafe.com/akuandev/Specs.git
pod repo update
這是使用gitcafe上的鏡像,將以上代碼中的 https://gitcafe.com/akuandev/Specs.git
替換成 http://git.oschina.net/akuandev/Specs.git 即可使用oschina上的鏡像瘟斜。