国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

Cocoapods詳解之---進階篇2

2019-11-07 23:29:31
字體:
來源:轉載
供稿:網友

CocoaPods 詳解之----更新篇

博客原地址:http://foggry.com/blog/2016/03/23/cocoapods-xiang-jie-zhi-geng-xin-pian/

CocoaPods 大概是 2011 年出現的開源組件管理工具(目前已支持 Objective-C 和 Swift),近年來普及率越來越高,幾乎已是所有 Cocoa 開源項目的標配。另外,很多大點的團隊會用 CocoaPods 拆分工程,實現項目插件化。

博主曾在 2014 年寫過 CocoaPods 詳解 系列文章:CocoaPods詳解之——使用篇、CocoaPods詳解之——進階篇、CocoaPods詳解之——制作篇,簡單介紹了從使用到親手制作 CocoaPods 開源組件的過程。

然而隨著時間的推移,CocoaPods 有些使用方式也發生了變化,比如組件提交方式等。本文將從 Trunk 和私有倉庫兩個方面介紹自己對 CocoaPods 的新認識。

一、Trunk 方式提交開源組件

從 CocoaPods 0.33 版本開始,CocoaPods 將組件的提交從 Pull requests 變成了自動化的 Trunk 方式。Trunk 提交方式有以下步驟:

1、向 Trunk 注冊自己的電腦

首次使用 Trunk 時,需要注冊自己的電腦:

12
# pod trunk register [E-mail] [User Name]$ pod trunk register foggry@foggry.com "foggry"

執行命令以后,上述郵箱會收到一封驗證郵件,按照郵件說明打開制定的鏈接,注冊流程就完成了。

注冊流程完成后,可以使用命令:

1
$ pod trunk me

可以檢驗注冊結果,如果輸出:

123456
- Name:     foggry- Email:    foggry@foggry.com- Since:    May 19th, 2014 16:03- Pods:     None- sessions:- March 19th, 22:23 - July 25th, 22:26. ip: 10.1.1.1

則說明注冊成功。

2、提交組件

準備好 podspec 文件后,首先要檢查其合法性:

12
# Enter podspec path$ pod lib lint

解決完錯誤和警告后,會顯示以下內容:

123
-> FGMarqueeView (1.0.0)FGMarqueeView passed validation.

這就說明驗證可以提交了。

執行提交命令:

1
$ pod trunk push WZMarqueeView.podspec

如果順利的話,會輸出以下內容:

1234567891011
Updating spec repo `master`Validating podspec-> WZMarqueeView (2.0.0)Updating spec repo `master`- Data URL: https://raw.githubusercontent.com/CocoaPods/Specs/1f2d70d978843a29cbe17b2476ffed8204eea6ef/Specs/WZMarqueeView/2.0.0/WZMarqueeView.podspec.json- Log messages:- March 21st, 00:49: Push for `WZMarqueeView 2.0.0' initiated.- March 21st, 00:49: Push for `WZMarqueeView 2.0.0' has been pushed (2.327208585 s).

僅需要這一條命令,開源組件就被推送到 CocoaPods 主倉庫中了。可以執行以下命令驗證下:

1
$ pod search WZMarqueeView

輸出為:

123456
-> WZMarqueeView (2.0.0)A marquee view used on iOS.pod 'WZMarqueeView', '~> 2.0.0'- Homepage: https://github.com/wangzz/WZMarqueeView- Source:   https://github.com/wangzz/WZMarqueeView.git- Versions: 2.0.0, 1.0.0 [master repo]

說明組件 WZMarqueeView 已經成功從 1.0.0 升級成了 2.0.0 版本。

3、其它說明

權限聲明

在執行下述命令時:

1
$ pod trunk push WZMarqueeView.podspec

提示了以下錯誤:

123456
Updating spec repo `master`Validating podspec-> WZMarqueeView (2.0.0)[!] You are not allowed to push new versions for this pod.

原來,Trunk 要求只有組件所有者和開發者才能更新已有組件,而上例的組件 WZMarqueeView 是 2014 年通過 Pull requests 方式上傳到 CocoaPods 主倉庫的,并沒有聲明過所有權。

隨后,到 CocoaPods 指定的網頁:Claim your Pod上填寫對應信息后,按照提示執行命令:

1
$ pod trunk info WZMarqueeView

看到執行結果:

12345
WZMarqueeView- Versions:- 1.0.0 (2014-05-19 22:03:59 UTC)- Owners:- foggry <foggry@foggry.com>

組件的所有權已經變成了本人,此時再去執行 trunk push 命令時就正常了。

為組件添加其它所有者

一個組件可以通過以下命令,添加多個所有者(以郵箱為標識):

12
# pod trunk add-owner [Module Name] [Owner E-mail]$ pod trunk add-owner WZMarqueeView kyle@cocoapods.org

執行成功后,kyle@cocoapods.org 也變成了 WZMarqueeView 的所有者。

Pull requests 和 Trunk 對比

對于開發者來說,Pull requests 的操作過程十分繁瑣,需要開源組件制作者先 fork 一份主倉庫,然后將組件提交到 fork 后的倉庫,再 Pull requests 給 CocoaPods 主倉庫的維護者;

對 CocoaPods 主倉庫的維護者來說,需要手工一個個處理主倉庫的合并操作,通常第二天甚至需要更長時間 requests 才能被處理;

而 Trunk 方式,開發者只需要一條命令就能將組件上傳到主倉庫,并且 Trunk 方式是自動化的,幾乎不再需要主倉庫的維護者做任何工作,實時性更好。

另外,Trunk 增加了組件所有者的概念,非所有者無法提交組件的更新,這在一定程度上提高了 CocoaPods 的安全性。

二、創建私有 CocoaPods 倉庫

目前所有支持 CocoaPods 的開源組件,都存儲在 Github 上公共的 CocoaPods Specs 倉庫中,這種方式有以下缺點:

官方倉庫過大,里面的絕大多數組件都不是我們需要的,你一定忘不了首次執行 pod install 操作時那無盡的等待;

不能實現私有化,作為一個相當好用的組件管理工具,很多團隊都使用 CocoaPods 實現龐大項目的組件化,都放在公共倉庫肯定不行。

這時就需要創建一個和 CocoaPods Specs 類似的私有組件存儲倉庫。私有倉庫可以存放在自家公司的 Git 服務器上,也可以放在各大支持私有倉庫的 Git 平臺上,下面以支持免費私有倉庫的 coding.net為例說明 CocoaPods 私有倉庫的創建過程。

1、創建coding.net私有倉庫

按照 coding.net 官網提示創建一個私有倉庫即可。

2、本地初始化組件倉庫

執行以下命令:

12
# pod repo add [PRivate Repo Name] [GitHub HTTPS clone URL]$ pod repo add FGSpecs https://git.coding.net/foogry/FGSpecs.git

3、向倉庫中添加組件

將事先準備好的組件添加到倉庫中,組件可以存放在本地,也可以放在自家或網上的代碼托管平臺。執行以下命令:

12
# pod repo push [Private Repo Name] [Private podspec Path]$ pod repo push FGSpecs ~/Desktop/FGMarqueeView.podspec

執行成功以后,會有以下輸出:

12345678910111213141516
Validating spec-> FGMarqueeView (0.1.0)Updating the `FGSpecs' repoAlready up-to-date.Adding the spec to the `FGSpecs' repo- [Fix] FGMarqueeView (0.1.0)Pushing the `FGSpecs' repoTo git@git.coding.net:foogry/FGSpecs.gite2ad499..31a1a8e  master -> master

至此,本地和代碼托管平臺上的私有倉庫 FGSpecs 中就都已經添加了私有組件 FGMarqueeView。

4、使用私有倉庫中的組件

Podfile 文件中默認情況下已經隱式使用 source 聲明了 CocoaPods 的官方倉庫。但使用私有組件,需要使用 source 關鍵字鮮顯式聲明組件所在倉庫:

12345678
# Private Specssource 'https://git.coding.net/foogry/FGSpecs.git'# Public Specssource 'https://github.com/CocoaPods/Specs.git'pod 'FGMarqueeView', '~> 0.1.0'pod 'SBJson', '~> 4.0.0'

其中,SBJson 組件是官方倉庫的,FGMarqueeView 組件屬于我們剛創建的私有倉庫。

需要注意的是:

官方倉庫的顯式聲明

盡管官方倉庫會被隱式聲明,如果同時使用了官方倉庫和私有倉庫,就需要同時聲明二者。

倉庫聲明順序性

先聲明的倉庫具有優先權。當先后引用的兩個倉庫中都包含同一個組件時,會使用先引用倉庫中的,哪怕后引用的倉庫中版本號更高。

5、直接使用私有組件

如果不想創建私有倉庫,也可以在 Podfile 里直接引用私有組件(組件可以是本地的,也可以是托管在自家公司服務器或網上的代碼托管平臺上的),引用的同時還可以制定具體的 commit、branch 或者 tag,比如:

1
$ pod 'FGMarqueeView', :git => 'https://git.coding.net/foogry/FGMarqueeView.git', :commit => 'b4dc0ffee'

這種方式引用的組件在執行完 pod install 以后,會被添加在 Development Pods 目錄下,而通過私有倉庫或共有倉庫方式引用的組件則會被添加在 Pods 目錄下。

三、cocoapods 版本管理

cocoapods 升級新版本后可能會遇到坑,因此就有了降級的需求。

查看當前版本
1
sudo gem list cocoapods
卸載當前版本
1
sudo gem uninstall cocoapods
安裝指定版本
1
sudo gem install cocoapods -v 0.39.0

四、參考文檔

CocoaPods Trunk

Getting setup with Trunk

Private Pods

Podfile Syntax Reference

Downgrading or installing older version of Cocoapods


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 商水县| 兴和县| 汾西县| 冕宁县| 榆树市| 菏泽市| 绥阳县| 广饶县| 隆子县| 定州市| 财经| 柘荣县| 余干县| 全州县| 犍为县| 常德市| 兴化市| 尉氏县| 余干县| 云林县| 四川省| 胶南市| 重庆市| 普陀区| 富宁县| 北票市| 宁海县| 日喀则市| 巩义市| 胶州市| 拜泉县| 崇州市| 洪江市| 虞城县| 佛山市| 铅山县| 义马市| 昌江| 武功县| 手机| 东乡族自治县|