创建私有库
1、git服务器创建一个项目
2、clone项目到本地(git clone https://github.com/XXX.git)
3、创建工程
1、切换到该目录下
2、创建工程模版
pod lib create RKLAPPPrivatePrivateLibraries
3、配置相关的选择
选择平台:
What platform do you want to use?? [ iOS / macOS ]
>iOS
选择语言:
What language do you want to use?? [ Swift / ObjC ]
>ObjC
是否自动生成demo,选择Yes,方便以后测试:
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?
>RKLAPP
4、执行完以后,cd到工程目录下执行pod install
5、打开 RKLAPPPrivatePrivateLibraries.xcworkspace工程文件
4、编写podspec文件
1、目录下文件介绍
podspec该文件主要是用来描述项目名称、pod版本号、介绍、首页、作者信息、git源等等
README.md使用过GitHub的都会知道README的重要性,这个文件可以使用Markdown语法,主要展示在GitHub工程上的首页,README文件对于使用pod库的人来说有和没有这个文件,区别很明显的,此外有助于创建一个高质量的CocoaPods Quality Index
LICENSE要想是Spec仓库接收,就必须包含一个LICENSE。命令pod lib create 自动创建使用的是 MIT license
2、如果用第3步的命令创建工程模版,那么工程的目录下已经自动生成了.podspec(RKLAPPPrivatePrivateLibraries.podspec)。如果是已有的工程或者库文件目录,也可以利用pod命令自己制作.podspec文件,命令如下:
pod spec create "组件库名"
3、自动生成的podspec文件只是模版,需要结合工程的库文件、资源目录、远程代码仓库(第一步创建的远程代码仓库)修改补充podspec文件。
Pod::Spec.new do |s|
s.name = 'RKLAPPPrivatePrivateLibraries'
s.version = '0.1.0'
s.summary = 'A short description of RKLAPPPrivatePrivateLibraries.'
# 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/RKLAppPrivateLibraries/RKLAPPPrivatePrivateLibraries'
# s.screenshots = 'www.example.com/screenshots_1', 'www.example.com/screenshots_2'
s.license = { :type => 'MIT', :file => 'LICENSE' }
s.author = { 'RKLAppPrivateLibraries' => '[email protected]' }
s.source = { :git =>
'https://github.com/RKLAppPrivateLibraries/RKLAPPPrivatePrivateLibraries.git', :tag => s.version.to_s }
# s.social_media_url = 'https://twitter.com/'
s.ios.deployment_target = '8.0'
s.source_files = 'RKLAPPPrivatePrivateLibraries/Classes/**/*'# s.resource_bundles = {
# 'RKLAPPPrivatePrivateLibraries' => ['RKLAPPPrivatePrivateLibraries/Assets/*.png'] # }
# s.public_header_files = 'Pod/Classes/**/*.h'
# s.frameworks = 'UIKit', 'MapKit'
# s.dependency 'AFNetworking', '~> 2.3'
5、验证.podspec文件的格式是否正确
1、cd到xxx.podspec文件所在的目录下,用到一些命令
pod lib lint
解说:本地验证pod能否通过验证,如果失败使用下面命令: pod lib lint --verbose查看原因,或者使用pod lib lint --allow-warnings忽略警告错误
pod spec lint
解说:本地和远程验证pod能否通过验证,需要更新提交podspec到远程specs仓库,参考第7步,一般本地验证通过即可提交到远程specs仓库
pod lib lint --verbose
解说:加--verbose可以显示详细的检测过程,出错时会显示详细的错误信息
pod lib lint --verbose --allow-warnings
解说: 允许警告,用来解决由于代码中存在警告导致不能通过校验的问题
常见错误:
解决方案:设置Command Line Tools
6、提交工程代码
提交工程代码到远程代码仓库,可以利用git或者svn进行代码版本管理,提交代码到GitHub等, 初始化提交命令如下:
//初始化git版本管理仓库,模板代码已经初始化过此步骤可以忽略(有.git文件夹)
git init
//添加到暂存区
git add .
//提交到本地仓库
git commit -a -m '提交信息'
示例:git commit -a -m '添加pod组件库'
//打标签,注意此标签可能在podspec中用到,用于区分版本
git tag 1.0.0
//本地仓库与远程仓库关联(已关联过的,可以忽略)
git remote add origin
//拉取和合并本地与远程仓库
git pull origin master --allow-unrelated-histories
//本地仓库代码推送到远程
git push --set-upstream origin master
此时如果你报错,查看报错信息中如果有:“pre-receive hook declined”
说明存在权限问题,没有master分支的代码提交权限。分配权限后,就可以push成功。
//推送标签
git push --tags
7.提交podspec文件
1. 开源库提交
podspec文件到Cocopods官方仓库,首先在cocopods官方仓库中注册账号,命令如下:
pod trunk me //(检查是否注册trunk)
pod trunk register 邮箱 注册名字 --verbose
//(注册命令)
注册完成之后会给你的邮箱发个邮件,进入邮箱邮件里面有个链接,需要点击确认一下.之后开始提交,切换到有.podspec文件的组件工程根目录执行命令
pod trunk push 组件库名.podspec
pod trunk push 组件库名.podspec --allow-warning
2、私有库提交
私有仓库需要先添加到本地仓库,再push到远程仓库。
电脑查看目录:~/.cocoapods/repos/
1、添加到本地仓库, [email protected]/.git为远程specs库的地址,成功之后目录(~/.cocoapods/repos)新增了一个文件夹(组件库名)
pod repo add specs仓库名 specs远程仓库地址 //示例:pod repo add RKLAPPPrivatePrivateLibraries https://XXX/klrepo.git2、查看是否添加成功
pod repo list3、push到远程specs仓库
pod repo push 本地spec库名 本地.podsepc文件 //示例:pod repo push RKLAPPPrivatePrivateLibraries RKLAPPPrivatePrivateLibraries.podspec4、如果.podspec文件存在警告时不能成功push。
解决:Pod repo push 本地spec库名 本地.podsepc文件 --allow-warnings
8、 检查仓库是否发布成功
pod搜索验证:
pod search 组件库名
如果报错,搜索不到,建议更新下pod:
pod update
之后仍然搜索不到,那么进入CocoaPods缓存目录,删除缓存索引文件search_index.json:
cd ~/Library/Caches/CocoaPods
ls
rm -f search_index.json
9、使用
如果是开源库(公有的),修改podfile文件:
如果是私有仓库,建议在podfile文件开头添加source源:
最后执行命令进行安装:
pod install
参考:https://www.jianshu.com/p/c04f1d8b5b61