CocoaPods 私有庫(kù)創(chuàng)建和更新

這里使用的代碼托管平臺(tái)是碼云上創(chuàng)建。

還可以使用github(之前不能免費(fèi)創(chuàng)建私有庫(kù),但現(xiàn)在可以了)、Coding等。

操作步驟:
一、創(chuàng)建兩個(gè)私有倉(cāng)庫(kù)
二、創(chuàng)建 spec repo
三、創(chuàng)建pod所需項(xiàng)目工程文件,并上傳到pod遠(yuǎn)程私有庫(kù)
四、向私有的spec Repo遠(yuǎn)程倉(cāng)庫(kù)中提交podspec
五、使用創(chuàng)建的私有pod庫(kù)
六、私有庫(kù)更新

一、創(chuàng)建兩個(gè)私有倉(cāng)庫(kù)

一個(gè)存放repo,一個(gè)存放pod所需項(xiàng)目工程文件

repo庫(kù)

pod庫(kù)

注意:

1、選擇私有

2、repo庫(kù)默認(rèn)選擇初始化

3、pod庫(kù)默認(rèn)不初始化

二、創(chuàng)建 spec repo

1、查看本地倉(cāng)庫(kù)

pod repo

2、添加遠(yuǎn)程repo庫(kù)

pod repo add 倉(cāng)庫(kù)名 倉(cāng)庫(kù)SSH(HTTPS)地址

pod repo add hftestrepo https://gitee.com/****/hftest-repo.git

添加之后,再次執(zhí)行pod repo 查看是否成功

還可以 通過(guò) ~/.cocoapods/repos 到對(duì)應(yīng)路徑下查看

三、創(chuàng)建pod所需項(xiàng)目工程文件,并上傳到pod遠(yuǎn)程私有庫(kù)

1、設(shè)定一個(gè)目標(biāo)文件并創(chuàng)建私有庫(kù)

cd 目標(biāo)文件夾

pod lib create HFTestKit (HFTestKit私有倉(cāng)庫(kù)名)

創(chuàng)建成功之后會(huì)自動(dòng)打開(kāi)上述工程文件。

1、pod lib create 創(chuàng)建成功的工程

2、選項(xiàng)中勾選得到示例工程

3、索引文件

4、自定義pod庫(kù)代碼位置

索引文件,相關(guān)字段有解釋?zhuān)梢圆榭?a target="_blank">cocoapods官方文檔了解更多。

Pod::Spec.new do |s|
  s.name             = 'HFTestKit'
  s.version          = '0.1.0'
  s.summary          = 'A short description of HFTestKit.'

# This description is used to generate tags and improve search results.
#   * Think: What does it do? Why did you write it? What is the focus?
#   * Try to keep it short, snappy and to the point.
#   * Write the description between the DESC delimiters below.
#   * Finally, don't worry about the indent, CocoaPods strips it!

  s.description      = <<-DESC
TODO: Add long description of the pod here.
                       DESC

  s.homepage         = 'https://gitee.com/****/hftest-kit'
  # s.screenshots     = 'www.example.com/screenshots_1', 'www.example.com/screenshots_2'
  s.license          = { :type => 'MIT', :file => 'LICENSE' }
  s.author           = { '****' => '****' }
  s.source           = { :git => 'https://gitee.com/****/hftest-kit.git', :tag => s.version.to_s }
  # s.social_media_url = 'https://twitter.com/<TWITTER_USERNAME>'

  s.ios.deployment_target = '10.0'

  s.source_files = 'HFTestKit/Classes/**/*'
  
  # s.resource_bundles = {
  #   'HFTestKit' => ['HFTestKit/Assets/*.png']
  # }

  # s.public_header_files = 'Pod/Classes/**/*.h'
  # s.frameworks = 'UIKit', 'MapKit'
  # s.dependency 'AFNetworking', '~> 2.3'
end

homepage:pod遠(yuǎn)程私有倉(cāng)庫(kù)地址,不帶.git

source:pod遠(yuǎn)程私有倉(cāng)庫(kù)地址,帶.git

注意修改為創(chuàng)建好的遠(yuǎn)程私有pod庫(kù)地址。

2、驗(yàn)證本地倉(cāng)庫(kù)

先cd 到HFTestKit路徑下,然后執(zhí)行

pod lib lint HFTestKit.podspec --allow-warnings

建議加—allow-warnings 因?yàn)橛芯鏁?huì)導(dǎo)致失敗。如果你能都解決警告也可以放開(kāi)。

得到 HFTestKit passed validation. 繼續(xù)執(zhí)行。

3、在Example工程中驗(yàn)證

增加一些類(lèi)

然后到Example工程下,執(zhí)行

pod install

打開(kāi)Example工程

4、將本地pod庫(kù)上傳到遠(yuǎn)程私有pod庫(kù)

cd 到 HFTestKit路徑下

git add .git
git commit -m "add manager"

git remote add origin https://gitee.com/lisa_1900/hftest-kit.git

git push https://gitee.com/****/hftest-kit.git main

注意:

5、指定tag

git tag 0.1.0 #這里的版本號(hào)必須和podspec中的s.version值相同
git push --tags

四、向私有的spec Repo遠(yuǎn)程倉(cāng)庫(kù)中提交podspec

hftestrepo是本地私有索引庫(kù)。

cd 到HFTestKit文件夾

pod repo push hftestrepo HFTestKit.podspec --allow-warnings --use-libraries

//--allow-warnings:加上該選項(xiàng),驗(yàn)證時(shí)如果有警告會(huì)忽略警告,否則無(wú)法驗(yàn)證通過(guò)
//--use-libraries:如果依賴(lài)了靜態(tài)庫(kù)就需要加上該選項(xiàng)

遠(yuǎn)程索引庫(kù)

本地索引庫(kù)

創(chuàng)建成功。

五、使用創(chuàng)建的私有pod庫(kù)

新建一個(gè)工程

Podfile文件內(nèi)

use_frameworks!

platform :ios, '10.0'
# 遠(yuǎn)程私有庫(kù)
source 'https://gitee.com/lisa_1900/hftest-repo.git'

target 'HFRepoDemo' do
    pod 'HFTestKit'
end

執(zhí)行pod install

#import "ViewController.h"
#import <hftestkit/HFTestUtil.h>
#import <hftestkit/HFTestManager.h>

@interface ViewController ()

@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view.
    self.view.backgroundColor = [UIColor redColor];
    [HFTestUtil hfUtil];
    [HFTestManager hfManagerMethods];
}
@end

可以正常使用。

因?yàn)槲覀兊膫}(cāng)庫(kù)都是私有的,所以在哪里需要安裝的話(huà),需要有對(duì)這兩個(gè)私有倉(cāng)庫(kù)的訪(fǎng)問(wèn)權(quán)限就好,發(fā)布公有的類(lèi)似,只是發(fā)布到了官方的 podspec 倉(cāng)庫(kù)。

六、私有庫(kù)更新

1、修改xxx/xxx/Classes文件夾下對(duì)應(yīng)的庫(kù)文件
2、更新測(cè)試工程的Pod庫(kù)文件: pod update --no-repo-update
3、更新xxx.podspec文件的配置信息, 版本號(hào)一定要改
4、提交代碼到遠(yuǎn)程倉(cāng)庫(kù): git push
5、更新tag標(biāo)簽:git tag -a 0.2.0 -m "0.1.0"git push --tags
6、更新遠(yuǎn)程和本地的私有索引庫(kù): pod repo push MyRepo XXX.podspec --allow-warnings

注意:

--no-repo-update:安裝pods之前不要更新pods倉(cāng)庫(kù)可以install、pod的速度更快一些。

1、修改xx/xx/Classes文件夾下的類(lèi):新增幾個(gè)類(lèi)

2、Example 工程 執(zhí)行

pod update --no-repo-update

3、修改podspec文件的配置信息, 版本號(hào)一定要改

4、代碼提交修改并推送到遠(yuǎn)程私有pod庫(kù)

git add .

git commit -m "commit message"

git push

5、更新tag,并推送至遠(yuǎn)程私有庫(kù)

git tag 0.2.1 #這里的版本號(hào)必須和podspec中的s.version值相同
git push --tags

6、更新遠(yuǎn)程和本地的私有索引庫(kù)

pod repo push hftestrepo HFTestKit.podspec --allow-warnings --use-libraries

pod repo push 本地私有索引庫(kù)名稱(chēng) XXX.podspec



注意:
多操作幾次,就可以熟練掌握的。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀(guān)點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容