第一次制作 CocoaPods 开源库

第一次制作 CocoaPods 开源库,简单的记录一下。

1、创建项目的Podspec描述文件

以 MBHUD 项目为例,把项目发布到github后,要打上tag。
项目根目录下执行

git tag -a 0.0.1 -m 'Version 0.0.1’
git push origin 0.0.1

之后我们在工程根目录中初始化一个Podspec文件:

pod spec create  MBHUD

该命令将在本目录产生一个名为MBHUD.podspec文件。用编辑器打开该文件,里面已经有非常丰富的说明文档。下面介绍如何声明第三方库的代码目录和资源目录,还有该第三方库所依赖ios核心框架和第三方库。这是我的podspec文件:

Pod::Spec.new do |s|

s.name         = "MBHUD"
s.version      = "0.0.3"
s.summary      = "站在巨人的肩上,MBProgressHUD 简单封装"

s.description  = <<-DESC
Let MBProgressHUD tu use simple
DESC

s.homepage     = "https://github.com/qyfeng009/MBHUD"
s.license      = { :type => "MIT", :file => "LICENSE" }
s.author             = { "qyfeng" => "[email protected]" }
s.ios.deployment_target = "8.0"
s.source       = { :git => "https://github.com/qyfeng009/MBHUD.git", :tag => "#{s.version}"
s.source_files  = "MBHUD/**/MBHUD.{h,m}" 
s.resources = "MBHUD/MBHUD/MBHUD.bundle"
s.frameworks = "UIKit", "Foundation"
s.requires_arc = true
s.dependency 'MBProgressHUD', '~> 1.0.0'
end

接下来讲解一下主要代码的含义,其他的文档中有详解
s.name:名称,pod search 搜索的关键词,注意这里一定要和.podspec的名称一样,否则报错
s.version:版本号
s.summary: 简介
s.homepage:声明库的主页
s.license:许可证
s.author:作者
s.ios.deployment_target:支持的pod最低版本
s.source:声明原代码的地址
s.source_files:声明了我们库的源代码的位置,所以这个地方不能填错了
s.resources: 资源文件
s.framework声明了所依赖的核心库,我这里只用到了UIKit
s.requires_arc: 是否支持ARC
s.dependency:依赖库

s.license= { :type => "MIT", :file => "LICENSE" }
这里建议这样写。
需要在创建 LICENSE 文件
LICENSE.gif

编辑完podspec文件后,需要验证一下这个文件是否可用,如果有任何WARNING或者ERROR都是不可以的,它就不能被添加到Spec Repo中,不过xcode的WARNING是可以存在的,验证需要执行命令:

pod spec lint MBHUD.podspec 或者  pod lib lint MBHUD.podspec
这个过程会出现一些错误,这里不一一列举,大家按照错误信息自行修改,不过一般不会出现错误,只要你按照样子,基本上是没有问题的

也会有这样的

第一次制作 CocoaPods 开源库_第1张图片
WARNING.png
验证时,也可能会出现警告如上,可以按照提示 执行 pod lib lint --allow-warnings 就会通过,不过发布时也需要加上 --allow-warnings

当看到HUPhotoBrowser passed validation.时,说明验证通过了。


第一次制作 CocoaPods 开源库_第2张图片
pass.png

2、CocoaPods Trunk发布自己的Pods

注册 Trunk
// 加上--verbose可以输出详细debug信息,方便出错时查看。
pod trunk register [email protected] "qyfeng" --verbose
大家在注册时需要替换成自己的邮箱和用户名,一切顺利的话就会受到一份邮件,点击邮件中的链接后验证一下:
查看注册信息
pod trunk me

Trunk push
pod trunk push 命令会首先验证你本地的podspec文件(是否有错误),之后会上传spec文件到trunk,最后会将你上传的podspec文件转换为需要的json文件。
如果你在手动验证 Pod 时使用了 --use-libraries 或 --allow-warnings 等修饰符,那么发布的时候也应该使用相同的字段修饰,否则出现相同的报错。
在工程根目录(包含有.podspec)下执行命令:

--allow-warnings 忽略警告类的错误, 
当你的库中用到了第三方的框架,上传的时候得加上--use-libraries
我在上传时执行了下面命令
pod trunk push MBHUD.podspec --use-libraries --allow-warnings

当出现如以下时即发布成功


第一次制作 CocoaPods 开源库_第3张图片
success.png
此时,可以验证以下
pod search MBHUD

如果搜不到,可以执行更新

pod setup

出现 如  HEAD is now at 30e244742d3 [Add] MBHUD 0.0.3,对应的tag就大公搞成了

第一次制作 CocoaPods 开源库_第4张图片
屏幕快照 2017-10-12 下午6.21.43.png

哦了,大功搞成

3、总结下下参看文档

如何发布自己的开源框架到CocoaPods http://www.cocoachina.com/ios/20160301/15459.html
[Cocoapods]项目添加Cocoapods支持遇到的坑 http://www.jianshu.com/p/283584683b0b
3分钟让你的框架支持cocoapods,podspec文件讲解 http://www.jianshu.com/p/8a7b9232cbab
如何写一个pod并发布到CocoaPods http://www.jianshu.com/p/89605e02bf18
发布自己的开源框架到Cocoapods http://www.jianshu.com/p/8e89b0fd7df8
cocoapods找不到第三方库Unable to find a pod with name, author, summary, or descriptionmatching http://www.jianshu.com/p/d2d81b58d716

你可能感兴趣的:(第一次制作 CocoaPods 开源库)