一、简介
公有库:开源自己封装的库供别人使用,且往cocoaPods的官方Repo仓库(即CocoaPods Master Repo)中新增自己库的索引,该库索引是以*.podspec.json文件形式存在。
私有库:私有库不在cocoaPods的官方Repo仓库中,而是在自建的spec repo中,库索引是以*.podspec文件形式存在,自建的spec repo放在路径~/.cocoapods/repos下,与master同级,其链接的远程仓库可以是公开的,也可以是私有的。
Spec Repo表示Repo仓库,是集合所有公开库的.podspec.json文件(索引文件)的git仓库。
当使用Cocoapods时它会被clone到本地的~/.cocoapods/repos目录下,进入目录后可以看到master文件夹,它就是官方的Spec Repo本地仓库。
因此创建CocoaPods私有库就需要有类似master的私有Spec Repo,让它关联远程git仓库。
二、搭建私有库和公有库
私有库和公有库前面搭建步骤是相同的,只在发布时操作不同。
1.github上新建空白项目YJPodTest。仓库网址为https://github.com/Manchitor/YJPodTest.git,该仓库链接我们的自定义库YJPodTest。
data:image/s3,"s3://crabby-images/e4629/e4629b0b914e805113662daf184f01c3e4e4e712" alt=""
2.创建Pods工程。选择你的代码库目录,执行命令pod lib create YJPodTest,依次回答终端问题。
data:image/s3,"s3://crabby-images/0f443/0f4430d1b6d099b07a85715d09f55aba3b61a4e0" alt=""
没关系,GitHub 会抽风,我们重试一下
data:image/s3,"s3://crabby-images/46125/461257606ff9835fb4e857fd0a22dcdc7ebadcc2" alt=""
data:image/s3,"s3://crabby-images/45a57/45a57e5bcda4153a0e69c0de55fc5917a2a610f5" alt=""
没关系,我们去YJPodTest/ Example项目里手动执行pod install
data:image/s3,"s3://crabby-images/02b63/02b63b12532acd60d7b4feb9cb22e43ae62a4e44" alt=""
3.编辑库文件,新建一个工具类 YJPodTestTool。
data:image/s3,"s3://crabby-images/4b6f7/4b6f7bb738ba96e7e7a69e64a663869fef22f01b" alt=""
data:image/s3,"s3://crabby-images/a5cfe/a5cfe296205f99fe01beee6c524ad92076772fee" alt=""
data:image/s3,"s3://crabby-images/c20db/c20dba395f72f08951991a405fda32014e7c765b" alt=""
并将这两个库文件放入YJPodTest/Classes中,删掉ReplaceMe.m文件。
data:image/s3,"s3://crabby-images/b1f95/b1f9532cc85e9053d237a4fdf6789180b6c8b51a" alt=""
Example是创建Pods工程时生成的一个工程,用于验证添加的库文件是否能正常使用。Example目录下Podfile文件中自动设置了YJPodTest依赖,如下:
data:image/s3,"s3://crabby-images/f38bc/f38bc70ab02b35fea2a397b7bc30d1f34bf4038d" alt=""
所以我们删除项目中我们新建的YJPodTestTool.h 和YJPodTestTool.m 其本意是模拟pod导入来自YJPodTest/Classes中的文件。
终端进入到Example下执行pod install 安装依赖
data:image/s3,"s3://crabby-images/3325d/3325d0081fc749d0937a0f3154cf7f642251cdde" alt=""
这个时候我们发现刚才我们YJPodTest/Classes下的库文件已经通过pod导入进来了
data:image/s3,"s3://crabby-images/48fca/48fcab957458bab7ec59af33ac6f4b2b298f32dc" alt=""
在Example 项目中就可以导入头文件并使用了
data:image/s3,"s3://crabby-images/3adc3/3adc332c52295ab158eb6bd7ef0b558f0a897b11" alt=""
4.提交pods库到github上
由于pod lib创建YJPodTest工程时默认已经准备了LICENSE、README.md、.gitignore三个文件,若在github上创建新建空白项目pod_test时勾选了这三个文件,则git pull时会产生冲突。解决方式:将YJPodTest工程目录下与github项目冲突的文件删除。
此外,YJPodTest目录下默认准备了.git仓库,会影响与github仓库的同步,删除掉。
cd到YJPodTest目录下
初始化git 并提交
data:image/s3,"s3://crabby-images/e46f4/e46f43efd49ad977bc415c70696cfa8c096c3744" alt=""
推送到远程仓库 命令为:git push origin master:main
data:image/s3,"s3://crabby-images/5a8e1/5a8e17225bef4f2c8e040eca9dab6a6fa07909e3" alt=""
此时你的github上就已经更新了
data:image/s3,"s3://crabby-images/9bd4f/9bd4f139d57d1d97da6c10333bcb6aaaa6b5370e" alt=""
5.配置Pods工程的.podspec文件。主要是s.version、s.summary、s.source的编辑。
data:image/s3,"s3://crabby-images/74bf1/74bf13ad8d1a9c64c2f687542e7f86618164a1d4" alt=""
data:image/s3,"s3://crabby-images/362b6/362b668418ec63ce36ddfb6233d42cd4c6aef067" alt=""
s.source_files = ‘YJPodTest/Classes//’,这里表示匹配所有子目录,表示匹配所有文件。
6.打标签,推送到远程。重点:tag打的版本号必须和podspec中的s.version值相同
data:image/s3,"s3://crabby-images/099f4/099f4b89280b76a1b0f0ca43b66c778085c601df" alt=""
7.验证.podspec文件的格式是否正确,必须打完tag才能验证,且必须验证,否则后面执行pod repo push或pod trunk push一定失败。
执行命令
data:image/s3,"s3://crabby-images/33372/333722dc2dbb0e7bd6c0ffa7e875fd0c7bf7355d" alt=""
data:image/s3,"s3://crabby-images/86390/86390d2ec0cae602e80a15c5f5f74db46358dd1c" alt=""
8.发布到私有库到Repo仓库
github上新建空白项目PodSpecTest,网址https://github.com/Manchitor/PodSpecTest.git,作为Repo仓库
data:image/s3,"s3://crabby-images/c4806/c480677511830df1df0f9729b65d4cac89daeb74" alt=""
在新建的文件目录下提交一个README.md 初始化git仓库,这里我创建的YJPodSpecTest 跟YJPodTest 同级
data:image/s3,"s3://crabby-images/1c941/1c941ec3c3145fe7a1e8efad24d3db526166ee87" alt=""
到YJPodSpecTest目录下初始化git仓库命令:
echo "# PodSpecTest" >> README.md
git init
git add README.md
git commit -m "first commit"
git branch -M main
git remote add origin https://github.com/Manchitor/PodSpecTest.git
git push -u origin main
回到本地生成私有的Spec Repo工作目录上层,执行
pod repo add YJPodSpecTest https://github.com/Manchitor/PodSpecTest.git
data:image/s3,"s3://crabby-images/956a2/956a20c97f14a085bfa9138d0fc22cf610ce2596" alt=""
那么在路径~/.cocoapods/repos下就会有YJPodTest本地仓库。
data:image/s3,"s3://crabby-images/cc5ef/cc5ef3cd42e1a14364ec9b551834d9fad9917244" alt=""
把YJPodTest.podspec提交到自建的Spec Repo仓库:
data:image/s3,"s3://crabby-images/12acd/12acd3048dc854d6974628887415bfd6d81fbcb7" alt=""
执行命令:将 YJPodTest.podspec 推到自己创建的Spec Repo (YJPodSpecTest)进行管理
pod repo push YJPodSpecTest YJPodTest.podspec
data:image/s3,"s3://crabby-images/df1a7/df1a7c96d6eef5c1bf33e5999e920d78c154ebd2" alt=""
报错如下:没关系 加上 --allow-warnings --use-libraries
data:image/s3,"s3://crabby-images/d4795/d4795764d31d85e8265473e2ee4ff128c0534091" alt=""
执行命令:pod repo push YJPodSpecTest YJPodTest.podspec --allow-warnings --use-libraries
data:image/s3,"s3://crabby-images/22ee5/22ee5b901169c45990af4d34aee223848ef3e01c" alt=""
这样私有库就制作好了。我们用pod search 'YJPodTest'试一下看能不能搜索到。
data:image/s3,"s3://crabby-images/dcf21/dcf215bc5e47e389637c36f9b8e13a34a105ea36" alt=""
附带一张GitHub Spec Repo 仓库截图
data:image/s3,"s3://crabby-images/e5863/e586323a83dd818315e12dca5ad7e4a5b8e60832" alt=""
9.发布到公有库
pod trunk push YJPodTest.podspec --allow-warnings --use-libraries
若显示"pod_test successfully published"就表示成功发布到官方Spec Repo仓库了。
若报错没有注册CocoaPods账号,则注册一个,命令(github_email填邮箱地址,'user_name’填作者名称):
pod trunk register github_email 'user_name' —verbose
然后到邮箱中收取邮件来点击验证注册,之后再执行一次pod trunk push pod_test.podspec --allow-warnings即可。(提醒:换台电脑,修改源码,提交到仓库时一样需要注册) 至此,公有库pod_test完成。 提交之后cocoaPods官网更新会延迟,耐心等待5-10分钟,然后将其更新到本地master spec repo
[图片上传失败...(image-ec5be3-1679368636189)]
网友评论