天天看点

手把手教你发布自己的CocoaPods开源库

本文讲的是<b>手把手教你发布自己的CocoaPods开源库,</b>发布自己的cocoapods开源库按照以下步骤,良心制作,包教包会!!

下面我会通过一个名为IFMMenu的项目来讲解一下整个过程。

1.写好代码,上传到github

github上创建项目仓库的时候记得创建LICENSE(许可证/授权)文件,此文件必须要有。

<a href="http://s1.51cto.com/wyfs02/M00/A4/96/wKioL1muLTvQW4VGAABDCzFC32M731.jpg-wh_651x-s_54694316.jpg" target="_blank"></a>

github上创建项目仓库

2.将自己的项目打成tag

因为cocoapods是依赖tag版本的,所以必须打tag,以后再次更新只需要把你的项目打一个tag,然后修改.podspec文件中的版本接着提交到cocoapods官方就可以了,提交命令请看下面

//为git打tag, 第一次需要在前面加一个v 

git tag "v1.0.0" 

git push --tags  

3.注册CocoaPods

trunk需要CocoaPods 0.33版本以上,用pod --version命令查看版本,如果版本低,需要升级。

pod --version 

//版本低于0.33 

sudo gen install cocoapods 

pod setup  

已经注册过的不需要注册,怎么看自己有没有注册

pod trunk me 

<a href="http://s3.51cto.com/wyfs02/M01/A4/96/wKioL1muLXWCxOfGAAA21nhW-RY039.jpg" target="_blank"></a>

pod trunk me信息

若未注册,执行以下命令,邮箱以及用户名请对号入座。用户名我使用的是Github上的用户名。

// 加上--verbose可以输出详细错误信息,方便出错时查看。 

pod trunk register [email protected] 'liugangios' --verbose  

注册完成之后会给你的邮箱发个邮件,进入邮箱邮件里面有个链接,需要点击确认一下。

注册完成后使用pod trunk me检验注册是否成功。

4.创建.podspec

cd到你项目的目录,执行命令

pod spec create IFMMenu 

5.编辑.podspec

创建好后,打开.podspec,删除注释, 前面有#的为注释,也可以用以下代码替换,然后编辑自己的库信息。

Pod::Spec.new do |s| 

s.name = 'IFMMenu' 

s.version = '1.0.2' 

s.authors = { 'liugangios' =&gt; '[email protected]' } 

s.homepage = 'https://github.com/liugangios/IFMMenu' 

s.summary = 'a dropdown menu for ios like wechat homepage.' 

s.source = { :git =&gt; 'https://github.com/liugangios/IFMMenu.git', 

:tag =&gt; s.version.to_s } 

s.license = { :type =&gt; "MIT", :file =&gt; "LICENSE" } 

s.platform = :ios, '7.0' 

s.requires_arc = true 

s.source_files = 'IFMMenu' 

s.public_header_files = 'IFMMenu/*.h' 

s.ios.deployment_target = '7.0' 

end  

s.name:名称,pod search搜索的关键词,注意这里一定要和.podspec的名称一样,否则报错

s.version:版本号,to_s:返回一个字符串

s.author:作者

s.homepage:项目主页地址

s.summary: 项目简介

s.source:项目源码所在地址

s.license:许可证

s.platform:项目支持平台

s.requires_arc: 是否支持ARC

s.source_files:需要包含的源文件

s.public_header_files:需要包含的头文件

s.ios.deployment_target:支持的pod最低版本

其他一些非必要字段

s.social_media_url:社交网址

s.resources:资源文件

s.dependency:依赖库,不能依赖未发布的库

s.license= { :type =&gt; “MIT”, :file =&gt; “LICENSE” } 

这里建议这样写,如果写别的会报警告,导致后面一直提交失败。

source_files写法及含义

"IFMMenu/* 

"IFMMenu/IFMMenu/*.{h,m}" 

"IFMMenu/**/*.h"  

*表示匹配所有文件

*.{h,m}表示匹配所有以.h和.m结尾的文件

**表示匹配所有子目录

s.source常见写法

s.source = { :git =&gt; "https://github.com/liugangios/IFMMenu.git", :commit =&gt; "68defea" } 

s.source = { :git =&gt; "https://github.com/liugangios/IFMMenu.git", :tag =&gt; 1.0.0 } 

s.source = { :git =&gt; "https://github.com/liugangios/IFMMenu.git", :tag =&gt; s.version }  

commit =&gt; "68defea" 表示将这个Pod版本与Git仓库中某个commit绑定

tag =&gt; 1.0.0表示将这个Pod版本与Git仓库中某个版本的comit绑定

tag =&gt; s.version表示将这个Pod版本与Git仓库中相同版本的comit绑定

6.验证.podspec

到此检查一下你工程中有以下文件:

你的项目,

.podspec文件,

LICENSE文件

<a href="http://s3.51cto.com/wyfs02/M01/05/E5/wKiom1muLh2S-QESAABJ1gHdcgk470.jpg" target="_blank"></a>

项目内文件

使用以下命令测试本地.podspec文件是否存在语法错误。

pod spec lint IFMMenu.podspec --verbose 

7.发布

pod trunk push IFMMenu.podspec 

时间较长,耐性等待,大概5-10分钟,发布成功后会有以下提示

<a href="http://s3.51cto.com/wyfs02/M02/05/E5/wKiom1muLjrhuT1kAACZs9vm5Eg941.jpg" target="_blank"></a>

发布成功截图

8.测试自己的cocoapods

这个时候使用pod search搜索的话会提示搜索不到,可以执行以下命令更新本地search_index.json文件

rm ~/Library/Caches/CocoaPods/search_index.json 

然后

pod search IFMMenu 

该命令会重新创建search_index.json文件,5-10分钟,耐性等待

<a href="http://s1.51cto.com/wyfs02/M00/A4/96/wKioL1muLj2Qqm4YAABJ8VBJGWo471.jpg" target="_blank"></a>

搜索结果

完整命令

git push --tags 

pod trunk register [email protected] 'liugangios' --verbose 

//编辑 IFMMenu.podspec 

pod spec lint IFMMenu.podspec 

pod search IFMMenu  

报错处理

[!] Unable to accept duplicate entry for: XXXXX (1.0.0) 

意思是:不能接受同一版本的提交

解决方案:

1、执行如下命令

git tag 1.0.1 

2、修改XXXX.podspec文件中的内容

s.version = "1.0.1" 

s.source = { :Git =&gt; "https://github.com/xxx/xxx.git", :tag =&gt; "1.0.1" }  

3、执行命令pod spec lint、pod trunk push 库名.podspec验证并提交到CocoPods

<b></b>

本文作者:佚名

来源:51CTO

原文标题:手把手教你发布自己的CocoaPods开源库