准备:
github账号,在GitHub上新建一个工程(工程名称就是这个库的名称)
cocoapods账号,注册流程如下,已注册过的verbose可以不加
pod trunk register 邮箱地址 '用户名' verbose
然后去邮箱看看,cocoapods官方会发一个邮件,点击邮件里的链接进行验证。
想验证是否注册成功,成功的话会打印出来账号邮箱等信息
pod trunk me
- Name: xinsun001
- Email: 1453724801@qq.com
- 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
创建好的工程会自动打开
配置:
在 ./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' => '1453724801@qq.com' }
//库的地址和版本,由于开发时还没有版本,所以tag的版本还没写
s.source = { :git => 'https://github.com/xinsun001/XSPodDemo.git', :tag => s.version.to_s }
//社交账号,不想写就不写
# s.social_media_url = 'https://twitter.com/<TWITTER_USERNAME>'
//最低支持的版本
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文件夹,所有的实现文件都要放在这个目录下面
到Example执行pod install,然后打开工程,看看pod文件里面,应该已经有你添加的那些文件了。
推送到远程:
这里的步骤和推送新的工程代码一致,命令如下:
cd到工程目录(含有REAMED.MD的那个目录)
git init
//注意这里不要再用https的方式了,用ssh的方式,要先去github上给你的电脑配置key
git remote add origin git@github.com: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命令,查看是否拉取成功。
!!!!鼓掌👏,现在,自己的远程库已经成功了
通过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
远程验证:
pod spec lint XSPodDemo.podspec --allow-warnings
提交到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'
成功后的打印
而且pod会给你的邮箱发送一个邮件
然后搜一下这个库
pod search XSPodDemo
搜不到的话,先清除本地的search
rm ~/Library/Caches/CocoaPods/search_index.json
还不行的话,更新pod
pod repo update
什么还是搜不到?那么可以放大招了,先
pod repo
然后删掉cocoapods
pod repo remove cocoapods
再重新添加进来
pod repo add cocoapods https://github.com/CocoaPods/Specs.git
之后就是漫长的等待,有可能会超时错误,重试就好。添加成功后再执行
pod search XSPodDemo
就可以看到了之后就可以在podfile文件里面直接进行引用了
pod 'XSPodDemo', '~> 0.1.0'
感谢阅读,如果觉得不错的话,给点个赞吧
本篇完!!!