在GitHub上做远程pod库

准备:

github账号,在GitHub上新建一个工程(工程名称就是这个库的名称)
cocoapods账号,注册流程如下,已注册过的verbose可以不加
pod trunk register 邮箱地址 '用户名' verbose
然后去邮箱看看,cocoapods官方会发一个邮件,点击邮件里的链接进行验证。
想验证是否注册成功,成功的话会打印出来账号邮箱等信息
pod trunk me

  - Name:     xinsun001
  - Email:    [email protected]
  - Since:    April 13th, 00:12
  - Pods:     None 

创建:

cd到要创建pod库的目录下,执行
pod lib create XSPodDemo
工程名称要和GitHub的一致。
如果在已有的项目上,先cd到项目目录,然后执行
pod spec create 项目名
会出现Cloning `https://github.com/CocoaPods/pod-template.git` into `XSPodDemo`.
然后要等一会,有可能会报超时错误,这时候重新执行命令就好,国内墙的原因。然后下面会有几个问题,跟着提示回答一下就好

//平台
What platform do you want to use?? [ iOS / macOS ]
 > iOS
//语言
What language do you want to use?? [ Swift / ObjC ]
 > ObjC
//是否需要一个demo工程
Would you like to include a demo application with your library? [ Yes / No ]
 > Yes
//测试框架
Which testing frameworks will you use? [ Specta / Kiwi / None ]
 > None
//是否要UI测试
Would you like to do view based testing? [ Yes / No ]
 > No
//类名的前缀
What is your class prefix?
 > XS

创建好的工程会自动打开


image.png

配置:

在 ./XSPodDemo/Podspec Metadata下面进行配置,如果是已有的项目,直接在项目下创建.podspec文件pod spec create 项目名,然后复制一个LECENSE文件
1 打开.podspec文件

# To learn more about a Podspec see https://guides.cocoapods.org/syntax/podspec.html
#
//这不要管
Pod::Spec.new do |s|
//库的名称,不用改
  s.name             = 'XSPodDemo'、
//初始版本号,别动
  s.version          = '0.1.0'
//对库的简单概括
  s.summary          = 'pod管理测试demo'

# 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://github.com/xinsun001/XSPodDemo'
  # s.screenshots     = 'www.example.com/screenshots_1', 'www.example.com/screenshots_2'
//协议类型
  s.license          = { :type => 'MIT', :file => 'LICENSE' }
//作者和邮箱
  s.author           = { 'xinsun001' => '[email protected]' }
//库的地址和版本,由于开发时还没有版本,所以tag的版本还没写
  s.source           = { :git => 'https://github.com/xinsun001/XSPodDemo.git', :tag => s.version.to_s }
//社交账号,不想写就不写
  # s.social_media_url = 'https://twitter.com/'
//最低支持的版本
  s.ios.deployment_target = '10.0'
//库的本地路径,不要瞎写
  s.source_files = 'XSPodDemo/Classes/**/*'
//指定文件类型,上面一行没指定,就会读取所有的
  #  s.source_files = 'XSPodDemo/Classes/**/*.{h,m}'
//图片路径
  # s.resource_bundles = {
  #   'XSPodDemo' => ['XSPodDemo/Assets/*.png']
  # }
  # s.public_header_files = 'Pod/Classes/**/*.h'
//使用的frameworks
  # s.frameworks = 'UIKit', 'MapKit'
//其他依赖库
  # s.dependency 'AFNetworking', '~> 2.3'
end

2:README.md
库的介绍及使用等,随便写,注意一下邮箱和作者名称是不是你自己
3LISCENSE
协议文件,看一下作者和邮箱就行

添加库:

打开文件目录,找到Classes文件夹,所有的实现文件都要放在这个目录下面


image.png

到Example执行pod install,然后打开工程,看看pod文件里面,应该已经有你添加的那些文件了。


image.png

推送到远程:

这里的步骤和推送新的工程代码一致,命令如下:
cd到工程目录(含有REAMED.MD的那个目录)

git init
//注意这里不要再用https的方式了,用ssh的方式,要先去github上给你的电脑配置key
git remote add origin [email protected]:xinsun001/XSPodDemo.git
git add .
git commit -m "你的描述"
git branch -M main
git push -u origin main

推送成功后再github上可以看到你的代码了。验证你的pod是否可用,要找一个带有podfile的工程,在里面添加你的依赖,注意:git中间不要有空格
pod 'XSPodDemo', :git => "https://github.com/xinsun001/XSPodDemo.git"
在新的工程执行pod install命令,查看是否拉取成功。

image.png

!!!!鼓掌,现在,自己的远程库已经成功了

通过trunk push发布到cocoapods上面:

执行pod search XSPodDemo,你会发现搜不到,想要搜到的话,必须要打tag,就像Masonry那样,后面可以选择版本号,而且不用加:git地址.

git tag 0.1.0
git push --tags
//删除本地tag
git tag -d name
//删除远程tag
git tag -d [0.1.0] 
git push origin :refs/tags/0.1.0
//清除缓存
git rm -r --cached .

之后要把.podspec文件推到github的cocoapods工程的spec文件夹下面
查看.podspec是否合法:
pod lib lint --verbose
有报错:
[!] XSPodDemo did not pass validation, due to 4 warnings (but you can use `--allow-warnings` to ignore them). You can use the `--no-clean` option to inspect any issue.
还没有正式生成 release 版本, github 上并没有任何 tag,所以我们刚才填写 .podspec 文件填写 git 地址的时候没有填写指定 tag,可以根据提示先把警告忽略:
pod lib lint --allow-warnings

image.png

远程验证:
pod spec lint XSPodDemo.podspec --allow-warnings
image.png

提交到pod,这里要等蛮长时间的,而且有几率超时导致错误。tag版本要指定,不然会报错
在.podspec中:
s.source = { :git => 'https://github.com/xinsun001/XSPodDemo.git', :tag => '0.1.0' }
推送:
pod trunk push XSPodDemo.podspec --verbose
如果有这个错误:[!] The spec did not pass validation, due to 3 warnings (but you can use `--allow-warnings` to ignore them).
可以在后面加--allow-warnings把警告忽略掉
pod trunk push XSPodDemo.podspec --verbose --allow-warnings
如果是私有库:
pod repo push youSpeces JCZJTest.podspec
youSpeces是你的cocoapods私有库,pod的时候需要在文件最上面加trunk:
source 'https://github.com/CocoaPods/youSpeces.git'
成功后的打印

image.png

而且pod会给你的邮箱发送一个邮件
image.png

然后搜一下这个库
pod search XSPodDemo
搜不到的话,先清除本地的search
rm ~/Library/Caches/CocoaPods/search_index.json
还不行的话,更新pod
pod repo update
什么还是搜不到?那么可以放大招了,先pod repo
image.png

然后删掉cocoapods
pod repo remove cocoapods
再重新添加进来
pod repo add cocoapods https://github.com/CocoaPods/Specs.git
之后就是漫长的等待,有可能会超时错误,重试就好。添加成功后再执行pod search XSPodDemo就可以看到了
image.png

之后就可以在podfile文件里面直接进行引用了
pod 'XSPodDemo', '~> 0.1.0'

感谢阅读,如果觉得不错的话,给点个赞吧
本篇完!!!

你可能感兴趣的:(在GitHub上做远程pod库)