一区二区三区日韩精品-日韩经典一区二区三区-五月激情综合丁香婷婷-欧美精品中文字幕专区

分享

CocoaPods安裝使用及配置私有庫

 南山岳麓書院 2015-12-03

從前端到obj-c有小半年了,文章又快有一年沒有更新過了,前幾天才把域名續(xù)費(fèi)了3年,感嘆第一個(gè)三年就這樣過去了….所以決定不能再像以前那樣懶了,每天堅(jiān)持把自己的學(xué)習(xí)都記錄下來然后有空的時(shí)候整理下發(fā)布到小站,于是有了obj-c的第一篇.

如何安裝?

1.安裝ruby環(huán)境,添加淘寶ruby鏡像

$ gem sources --remove https:///
//等有反應(yīng)之后再敲入以下命令
$ gem sources -a http://ruby./

2.查看是否設(shè)置成功:

$ gem sources -l

3.然后安裝cocoapods:

$ sudo gem install cocoapods

4.查看cocoapods是否支持某個(gè)類庫

$ pod search 類庫名,支持模糊查詢(如:AFNetworking)

如何使用?

  • 在項(xiàng)目根目錄下新建一個(gè)“Podfile”的文件(記住一定得叫這個(gè)名兒,而且木有后綴)

注:Podfile也可以放在任何位置,但是需要在Podfile頂部使用”xcodeproj”關(guān)鍵字指定工程的路徑,如下:

Podfile指明xcodeproj

Podfile指明xcodeproj

但是執(zhí)行pod install命令后,生成的文件放在了Podfile所在的目錄.

  • 編輯Podfile文件輸入以下信息

platform :iOS, ‘7.0’\\所有庫支持的IOS最低版本
pod ‘AFNetworking’, ‘~> 2.0’\\版本號(hào)

注:有些第三方庫需要指明:platform 支持的IOS最低版本,否則在pod install時(shí)會(huì)報(bào)錯(cuò),如下圖,提示AFNetworking最低支持IOS6.0和OS X 10.8

cocoapods指明ios版本

cocoapods指明ios版本

  • 然后在項(xiàng)目podfile所在目錄下運(yùn)行:(會(huì)在你當(dāng)前項(xiàng)目中導(dǎo)入podfile所配置的庫,所以要在項(xiàng)目目錄下運(yùn)行)

$ pod install

注意上述命令運(yùn)行完畢后終端輸出的最后一段話,意思就是以后打開項(xiàng)目就用CocoaPodsDemo.xcworkspace 打開,而不是之前的.xcodeproj文件。

[!] From now on use `CocoaPodsDemo.xcworkspace`.

經(jīng)過以上步驟后,我們現(xiàn)在可以打開CocoaPodsDemo.xcworkspace啟動(dòng)我們的新工程了.新工程中已經(jīng)通過cocoapods引入并配置好了我們剛在podfile寫的需要依賴的第三方庫了.

引入第三方庫后找不到頭文件?

在項(xiàng)目的Targe-Build Settings-Search Paths-User Header Searcj Paths中添加

${SRCROOT} 值為 recursive

如下圖:

cocoapods配置頭文件

cocoapods配置頭文件

如何編譯從github上checkout下來的一個(gè)已包含CocoPods類庫的項(xiàng)目?

打開終端進(jìn)入你所下載項(xiàng)目的根目錄,執(zhí)行以下命令,后會(huì)得到上面的那句話:

$ pod update

等待命令運(yùn)行完畢后,同樣最后會(huì)輸出

[!] From now on use `xxxxx.xcworkspace`.

如何刪除cocopods?

  1. 刪除工程文件夾下的Podfile、Podfile.lock及Pods文件夾
  2. 刪除xcworkspace文件
  3. 使用xcodeproj文件打開工程,刪除Frameworks組下的Pods.xcconfig及l(fā)ibPods.a引用
  4. 在工程設(shè)置中的Build Phases下刪除Check Pods Manifest.lock及Copy Pods Resources
刪除cocoapods

刪除cocoapods

CocoaPods常用命令

1、pod install

根據(jù)Podfile文件指定的內(nèi)容,安裝依賴庫,如果有Podfile.lock文件而且對(duì)應(yīng)的Podfile文件未被修改,則會(huì)根據(jù)Podfile.lock文件指定的版本安裝。

每次更新了Podfile文件時(shí),都需要重新執(zhí)行該命令,以便重新安裝Pods依賴庫。

2、pod update

若果Podfile中指定的依賴庫版本不是寫死的,當(dāng)對(duì)應(yīng)的依賴庫有了更新,無論有沒有Podfile.lock文件都會(huì)去獲取Podfile文件描述的允許獲取到的最新依賴庫版本。

3、pod search

命令格式為:

$ pod search 類庫名,支持模糊查詢(如:AFNetworking)

pod search功能

pod search功能

紅框中的信息為AFNetworking 最新版本,Version中顯示了歷史版本,根據(jù)這些信息來編寫我們的Podfile文件如:

pod ‘AFNetWorking’, ‘~> 2.2.4′

這句話具體含義是什么呢?
當(dāng)我們通過cocopods引入依賴庫時(shí),需要顯示或隱式注明引用的依賴庫版本,具體寫法和表示含義如下

pod ‘AFNetworking’      //不顯式指定依賴庫版本,表示每次都獲取最新版本
pod ‘AFNetworking’, ‘2.0’     //只使用2.0版本
pod ‘AFNetworking’, ‘> 2.0’     //使用高于2.0的版本
pod ‘AFNetworking’, ‘>= 2.0’     //使用大于或等于2.0的版本
pod ‘AFNetworking’, ‘< 2.0’     //使用小于2.0的版本
pod ‘AFNetworking’, ‘<= 2.0’     //使用小于或等于2.0的版本
pod ‘AFNetworking’, ‘~> 0.1.2’     //使用大于等于0.1.2但小于0.2的版本
pod ‘AFNetworking’, ‘~>0.1’     //使用大于等于0.1但小于1.0的版本
pod ‘AFNetworking’, ‘~>0’     //高于0的版本,寫這個(gè)限制和什么都不寫是一個(gè)效果,都表示使用最新版本

4、pod setup

用于跟新本地電腦上的保存的Pods依賴庫tree。由于每天有很多人會(huì)創(chuàng)建或者更新Pods依賴庫,這條命令執(zhí)行的時(shí)候會(huì)相當(dāng)慢,還請(qǐng)耐心等待。我們需要經(jīng)常執(zhí)行這條命令,否則有新的Pods依賴庫的時(shí)候執(zhí)行pod search命令是搜不出來的。

①多個(gè)target中使用相同的Pods依賴庫

比如,名稱為CocoaPodsTest的target和Second的target都需要使用Reachability、SBJson、AFNetworking三個(gè)Pods依賴庫,可以使用link_with關(guān)鍵字來實(shí)現(xiàn),將Podfile寫成如下方式:

link_with ‘CocoaPodsTest’, ‘Second’
platform :ios
pod ‘Reachability’,  ‘~> 3.0.0’
pod ‘SBJson’, ‘~> 4.0.0’

platform :ios, ‘7.0’
pod ‘AFNetworking’, ‘~> 2.0’

這種寫法就實(shí)現(xiàn)了CocoaPodsTest和Second兩個(gè)target共用相同的Pods依賴庫。

②不同的target使用完全不同的Pods依賴庫

CocoaPodsTest這個(gè)target使用的是Reachability、SBJson、AFNetworking三個(gè)依賴庫,但Second這個(gè)target只需要使用OpenUDID這一個(gè)依賴庫,這時(shí)可以使用target關(guān)鍵字,Podfile的描述方式如下:

target :’CocoaPodsTest’ do
platform :ios
pod ‘Reachability’,  ‘~> 3.0.0’
pod ‘SBJson’, ‘~> 4.0.0’

platform :ios, ‘7.0’
pod ‘AFNetworking’, ‘~> 2.0′
end

target :’Second’ do
pod ‘OpenUDID’, ‘~> 1.0.0’
end

其中,do/end作為開始和結(jié)束標(biāo)識(shí)符。

Podfile.lock文件

在使用CocoaPods,執(zhí)行完pod install之后,會(huì)生成一個(gè)Podfile.lock文件。這個(gè)文件看起來跟我們關(guān)系不大,實(shí)際上絕對(duì)不應(yīng)該忽略它。
該文件用于保存已經(jīng)安裝的Pods依賴庫的版本,通過CocoaPods安裝了SBJson、AFNetworking、Reachability三個(gè)POds依賴庫以后對(duì)應(yīng)的Podfile.lock文件內(nèi)容為:

PODS:
– AFNetworking (2.1.0):
– AFNetworking/NSURLConnection
– AFNetworking/NSURLSession
– AFNetworking/Reachability
– AFNetworking/Security
– AFNetworking/Serialization
– AFNetworking/UIKit
– AFNetworking/NSURLConnection (2.1.0):
– AFNetworking/Reachability
– AFNetworking/Security
– AFNetworking/Serialization
– AFNetworking/NSURLSession (2.1.0):
– AFNetworking/NSURLConnection
– AFNetworking/Reachability (2.1.0)
– AFNetworking/Security (2.1.0)
– AFNetworking/Serialization (2.1.0)
– AFNetworking/UIKit (2.1.0):
– AFNetworking/NSURLConnection
– Reachability (3.0.0)
– SBJson (4.0.0)

DEPENDENCIES:
– AFNetworking (~> 2.0)
– Reachability (~> 3.0.0)
– SBJson (~> 4.0.0)

SPEC CHECKSUMS:
AFNetworking: c7d7901a83f631414c7eda1737261f696101a5cd
Reachability: 500bd76bf6cd8ff2c6fb715fc5f44ef6e4c024f2
SBJson: f3c686806e8e36ab89e020189ac582ba26ec4220

COCOAPODS: 0.29.0

Podfile.lock文件最大得用處在于多人開發(fā)。當(dāng)團(tuán)隊(duì)中的某個(gè)人執(zhí)行完pod install命令后,生成的Podfile.lock文件就記錄下了當(dāng)時(shí)最新Pods依賴庫的版本,這時(shí)團(tuán)隊(duì)中的其它人check下來這份包含Podfile.lock文件的工程以后,再去執(zhí)行pod install命令時(shí),獲取下來的Pods依賴庫的版本就和最開始用戶獲取到的版本一致。如果沒有Podfile.lock文件,后續(xù)所有用戶執(zhí)行pod install命令都會(huì)獲取最新版本的SBJson,這就有可能造成同一個(gè)團(tuán)隊(duì)使用的依賴庫版本不一致,這對(duì)團(tuán)隊(duì)協(xié)作來說絕對(duì)是個(gè)災(zāi)難!
在這種情況下,如果團(tuán)隊(duì)想使用當(dāng)前最新版本的SBJson依賴庫,有兩種方案:

  1. 更改Podfile,使其指向最新版本的SBJson依賴庫;
  2. 執(zhí)行pod update命令;

鑒于Podfile.lock文件對(duì)團(tuán)隊(duì)協(xié)作如此重要,我們需要將它添加到版本管理中。

如何制作自己的Cocopods庫

1.在github上新建一個(gè)工程

github上新建pod工程

github上新建pod工程

license類型

正規(guī)的倉庫都應(yīng)該有一個(gè)license文件,Pods依賴庫對(duì)這個(gè)文件的要求更嚴(yán),是必須要有的。因此最好在這里讓github創(chuàng)建一個(gè),也可以自己后續(xù)再創(chuàng)建。我使用的license類型是MIT。

把項(xiàng)目clone到本地然后在根目錄下新建MyPodDemo.podspec

或使用命令

$ pod spec create MyPodDemo

Spec文件編寫:

Pod::Spec.new do |s|
 s.name = "MyPodDemo"
 s.version = "0.0.1"
 s.summary = "A short description of MyPodDemo."
 s.description = <<-DESC
 A longer description of MyPodDemo in Markdown format.
 * Think: Why did you write this? What is the focus? What does it do?
 * CocoaPods will be using this to generate tags, and improve search results.
 * Try to keep it short, snappy and to the point.
 * Finally, don't worry about the indent, CocoaPods strips it!
 DESC
 s.homepage = "https://github.com/goingta/MyPodDemo"
 s.license = "MIT"
 s.author = { "goingta" => "tangle1128@gmail.com" }
 s.source = { :git => "https://github.com/goingta/MyPodDemo.git", :tag => "0.0.1" }
 s.source_files = "MyPodDemo/Src", "MyPodDemo/Src/**/*.{h,m}"
 s.requires_arc = true
 # s.framework = "SomeFramework"
 # s.frameworks = "SomeFramework", "AnotherFramework"
 # s.library = "iconv"
 # s.libraries = "iconv", "xml2"
 # s.dependency "JSONKit", "~> 1.4"
 # s.dependency "AFNetworking", "~> 2.2.4"
 end

自解析:

 name: 導(dǎo)入pod后的目錄名
 version: 當(dāng)前版本號(hào)
 deployment_target: 配置的target
 prefix_header_file: 預(yù)編譯頭文件路徑,將該文件的內(nèi)容插入到Pod的pch文件內(nèi)
 source: 來源的具體路徑,是http鏈接還是本地路徑
 requires_arc: 是否需要arc
 source_files: 指定該目錄下包含哪些文件
 其他可選參數(shù)還包括:
 dependency: 指定依賴,如果依賴的庫不存在或者依賴庫的版本不符合要求將會(huì)報(bào)錯(cuò)
 libraries: 指定導(dǎo)入的庫,比如sqlite3
 frameworks: 指定導(dǎo)入的framework
 weak_frameworks: 弱鏈接,比如說一個(gè)項(xiàng)目同時(shí)兼容iOS6和iOS7,但某一個(gè)framework只在iOS7上有,這時(shí)候如果用強(qiáng)鏈接,那么在iOS7上運(yùn)行就會(huì)crash,使用weak_frameworks可以避免這種情況。

整個(gè)podspec語法是一個(gè)嵌套結(jié)構(gòu)從Pod::Spec.new do |s|到最后一個(gè)end是最大的循環(huán),表示整個(gè)podspec導(dǎo)入的文件。中間每一個(gè)subspec到end結(jié)束是一個(gè)子目錄,Pods會(huì)為每個(gè)subspec創(chuàng)建一個(gè)邏輯目錄,相當(dāng)于Xcode的group概念。|**|中間是subspec的名字,可以隨便命名,但后面使用的名稱必須一致。

通配符說明

a{bb,bc}def.{h,m}表示四個(gè)文件abbdef.h abbdef.m abcdef.h abcdef.m

*.{h,m,mm}表示所有的.h .m .mm文件
Class/**/*.{h,m}表示Class目錄下的所有.h .m文件

寫完podspec文件后使用pod spec lint驗(yàn)證spec是否合格,有error則需要修改

 

spec文件驗(yàn)證

spec文件驗(yàn)證

上傳代碼至github

上傳podspec文件到CocoaPods倉庫(fork一下,修改完成后在push上去等待審核)

將我們剛剛生成的MyPodDemo.spec 文件上傳到Cocoapods官方specs倉庫中 :
鏈接為:https://github.com/CocoaPods/Specs

私有庫實(shí)現(xiàn),編寫podfile

如果由于某些原因我們編寫的庫不能公開,但是又想使用pods來進(jìn)行管理,要怎么辦呢?

首先我們要將我們剛剛在github上建的倉庫改為Private(不然還用Public搞毛啊)

然后修改我們項(xiàng)目的podfile,與已加入Cocopods倉庫的公有庫相比我們只需要指明私有庫低git地址,如下:

platform :ios, '6.0'
pod 'MyPodDemo', :git => 'https://github.com/goingta/MyPodDemo.git' //私有庫
pod 'CocoaLumberjack'//公有庫

版本控制和沖突(引用自http:///issue-6-4/)

CocoaPods 使用語義版本控制 – Semantic Versioning 命名約定來解決對(duì)版本的依賴。由于沖突解決系統(tǒng)建立在非重大變更的補(bǔ)丁版本之間,這使得解決依賴關(guān)系變得容易很多。例如,兩個(gè)不同的 pods 依賴于 CocoaLumberjack 的兩個(gè)版本,假設(shè)一個(gè)依賴于2.3.1,另一個(gè)依賴于 2.3.3,此時(shí)沖突解決系統(tǒng)可以使用最新的版本 2.3.3,因?yàn)檫@個(gè)可以向后與 2.3.1 兼容。

但這并不總是有效。有許多第三方庫并不使用這樣的約定,這讓解決方案變得非常復(fù)雜。

當(dāng)然,總會(huì)有一些沖突需要手動(dòng)解決。如果一個(gè)庫依賴于 CocoaLumberjack 的 1.2.5,另外一個(gè)庫則依賴于 2.3.1,那么只有最終用戶通過明確指定使用某個(gè)版本來解決沖突。

配置非ARC文件(8.5號(hào)補(bǔ)充)

前幾天項(xiàng)目中由于歷史原因,導(dǎo)致有一個(gè)私有的pods庫中某幾個(gè)文件是在非ARC時(shí)代寫的,如果要進(jìn)行修改工程量浩大,于是乎要對(duì)這幾個(gè)文件單獨(dú)處理,這幾個(gè)文件不使用arc其他文件使用arc,網(wǎng)上查了一些資料,只需要對(duì)source_file進(jìn)行修改并排除那幾個(gè)不使用ARC的文件就可以了,大致修改如下:

Pod::Spec.new do |s|
 s.name = "MyPodDemo"
 s.version = "0.0.1"
 s.summary = "A short description of MyPodDemo.
 s.homepage = "https://github.com/goingta/MyPodDemo"
 s.license = "MIT"
 s.author = { "goingta" => "tangle1128@gmail.com" }
 s.source = { :git => "https://github.com/goingta/MyPodDemo.git", :tag => "0.0.1" }
 s.source_files = "MyPodDemo"
 non_arc_files = 'MyPodDemo/NoArcFile1.{h,m}','MyPodDemo/NoArcFile2.{h,m}'
 s.requires_arc = true

 s.exclude_files = non_arc_files
 s.subspec 'no-arc' do |sna|
 sna.requires_arc = false
 sna.source_files = non_arc_files
 end
end

回退Cocoapods歷史版本(2015.3.17號(hào)補(bǔ)充)

查看當(dāng)前安裝了哪些版本

gem list --local | grep cocoapods

如果你安裝了多個(gè)版本(如0.35和0.20.2)那么你將看到

cocoapods (0.34, 0.20.2)
cocoapods-core (0.33, 0.20.2)
cocoapods-downloader (0.2.0, 0.1.2)

先刪除已經(jīng)裝過的版本(可能有幾個(gè),卸載的時(shí)候會(huì)讓你輸入1,2..n選擇卸載那個(gè)版本

sudo gem uninstall cocoapods

或者強(qiáng)制卸載某一個(gè)版本

gem uninstall cocoapods -v 0.20.2

安裝某一個(gè)版本

sudo gem install cocoapods -v 0.35.0

處理 Use the `$(inherited)` flag 異常(2015.6.03補(bǔ)充)

有時(shí)候在pod update之后會(huì)遇到下面錯(cuò)誤:

 - Use the `$(inherited)` flag, or
 - Remove the build settings from the target.

雖然對(duì)項(xiàng)目編譯沒什么影響,但是看著還是挺不舒服的.解決辦法就是

找到工程的 targets 點(diǎn)擊工程名  Build Settings -> Other linker flags -> 添加 $(inherited)

無覓相關(guān)文章插件,快速提升流量

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多

    最新日韩精品一推荐日韩精品| 欧美日韩一区二区三区色拉拉| 欧美日韩人妻中文一区二区| 色丁香一区二区黑人巨大| 激情爱爱一区二区三区| 亚洲综合日韩精品欧美综合区| 国产又粗又猛又黄又爽视频免费| 久久精品a毛片看国产成人| 伊人久久青草地综合婷婷| 日韩精品一区二区不卡| 日本道播放一区二区三区| 国内精品偷拍视频久久| 国产亚洲视频香蕉一区| 日本丰满大奶熟女一区二区| 精品人妻一区二区三区四区久久| 伊人久久青草地综合婷婷| 亚洲精品福利入口在线| 亚洲视频在线观看免费中文字幕| 欧美日韩国产精品自在自线| 中文字幕亚洲在线一区| 丰满的人妻一区二区三区| 欧美日韩亚洲精品在线观看| 久久热在线免费视频精品| 国产一区在线免费国产一区| 日韩精品中文字幕亚洲| 久热99中文字幕视频在线| 白丝美女被插入视频在线观看| 久久精品久久久精品久久| 熟女免费视频一区二区| 国产午夜精品在线免费看| 久久天堂夜夜一本婷婷| 国内欲色一区二区三区| 丝袜破了有美女肉体免费观看 | 日本av一区二区不卡| 男生和女生哪个更好色| 69精品一区二区蜜桃视频| 日韩中文字幕人妻精品| 中文字幕亚洲视频一区二区| 免费播放一区二区三区四区| 日韩18一区二区三区| 日韩欧美三级中文字幕|