公司業務不斷的發展,需要各個業務部門配合開發相關模塊,公司不止有一個產品,當項目達到兩個及以上的時候,就需要考慮代碼的共用(理想情況下)。由于我們公司特殊情況(懶),原來做項目的時候沒有考慮這么多,由于公司新項目與原來的項目有大量功能相似,當時我們就采用了創建新分支的形式創建了新項目,導致代碼耦合性非常強,平常開發中遇到很多問題,比如:
- 有些代碼可能這個項目需要,那個項目不需要
- 分支切換太過頻繁
- 創建了大量分支
- 在這個分支上開發的時候,測試需要另一個項目的包,需要來回切換
。。。等等
此時git 版本管理起來會顯得比較吃力,經過研究我們可以通過創建cocoapods 私有庫來管理我模塊的代碼
創建私有 Spec Repo
- 首先我們需要在公司git服務上創建一個私有庫來托管Spec Repo,執行命令
/*
xxx 私有spec repo 名稱
xxxx 創建的git 倉庫的地址
*/
pod repo add xxx xxxx
/*
查看所有spec repo 列表
*/
pod repo list
創建一個git 倉庫管理項目代碼
- 克隆項目到本地指定文件夾A
git clone xxxx
- 在文件夾A下創建工程,并進入工程項目下,創建cocopods配置文件
pod spec create xxx
xxx.podspec 文件各字段含義
name:框架名
version:當前版本(注意,是當前版本,假如你后續更新了新版本,需要修改此處)
summary:簡要描述,在pod search ZCPKit的時候會顯示該信息。
description:詳細描述
homepage:頁面鏈接
license:開源協議
author:作者
source:源碼git地址
platform:支持最低ios版本
source_files:源文件(可以包含.h和.m)
public_header_files:頭文件(.h文件)
resources:資源文件(配置的文件都會被放到mainBundle中)
resource_bundles:資源文件(配置的文件會放到你自己指定的bundle中)
frameworks:依賴的系統框架
vendored_frameworks:依賴的非系統框架
libraries:依賴的系統庫
vendored_libraries:依賴的非系統的靜態庫
dependency:依賴的三方庫
- 在podspec寫好之后我們需要驗證一下編寫的內容是否有誤。可以在命令行的三方庫當前路徑下使用下面的命令:
pod lib lint (從本地驗證你的pod能否通過驗證)
pod spec lint (從本地和遠程驗證你的pod能否通過驗證)
pod lib lint --verbose (加--verbose可以顯示詳細的檢測過程,出錯時會顯示詳細的錯誤信息)
pod lib lint --allow-warnings (允許警告,用來解決由于代碼中存在警告導致不能通過校驗的問題)
pod lib lint --help (查看所有可選參數,可選參數可以加多個)
- 驗證成功后,我們把代碼提交到git倉庫, 參考如下命令
git add .
git commit -m 'first add pod files'
git tag -a 0.0.1
git push --tags
git push master
- 我們將創建的podspec 提交到 spec Repository 執行 命令
pod repo push xxx xxx.podspec
- 使用說明podifle文件
建立后修改 Podfile 文件內容如下:
source 'https://github.com/CocoaPods/Specs.git' #官方倉庫地址
source ‘http://njGitrepo/wushuanghong/wshSpecs.git’ #私有倉庫地址
use_frameworks!
target 'TestPodDemo' do
pod ‘xxx’
end