如何利用CocoaPods创建私有库

创建私有库

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.git

2、查看是否添加成功
pod repo list

3、push到远程specs仓库
pod repo push 本地spec库名 本地.podsepc文件    //示例:pod repo push RKLAPPPrivatePrivateLibraries RKLAPPPrivatePrivateLibraries.podspec

4、如果.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

你可能感兴趣的:(如何利用CocoaPods创建私有库)