配置自己GitHub的开源项目,使用CocoaPods让其支持pod

整个流程,包括Github创建项目、上传项目,到最后的支持Cocoapods。
步骤如下:

  • GitHub创建存储库,上传代码,并且克隆项目到本地
  • 注册CocoaPods账号
  • 创建podspec文件,配置podspec文件信息,并且验证
  • 在Github上创建项目release版本
  • 上传代码到CocoaPods
  • 错误信息s.source_files解决办法

一、GitHub创建存储库,上传代码,并且克隆项目到本地

  • 打开github.com,然后创建自己的项目工程:
    配置自己GitHub的开源项目,使用CocoaPods让其支持pod_第1张图片
    image.png
配置自己GitHub的开源项目,使用CocoaPods让其支持pod_第2张图片
image.png
  • 通过终端命令或者github客户端将项目 clone 到本地
    并且把需要支持pod的文件或者demo放到里面,文件夹如下图所示:
    配置自己GitHub的开源项目,使用CocoaPods让其支持pod_第3张图片
    image.png

JYWKWebViewDemo是示例demo,JYWKWebView就是提供给他人使用的库,然后提交同步到Github。

二、 注册CocoaPods账号

  • 终端输入
// pod trunk register 邮箱地址 '用户名' --description='描述信息'
pod trunk register [email protected] 'zjy'  --description '创建CocoaPods'
  • 然后打开邮件中的链接, 这样就成功注册了Cocoapods账号。


    配置自己GitHub的开源项目,使用CocoaPods让其支持pod_第4张图片
    image.png
  • 检查是否创建成功,如下图表示创建成功

pod trunk me
配置自己GitHub的开源项目,使用CocoaPods让其支持pod_第5张图片
image.png

三、 创建podspec文件,配置podspec文件信息,并且验证

  • 打开终端,cd到项目文件夹下
  • 创建.podspec
// JYWebView为你需要支持pod的库名,文件名
pod spec create JYWebView
  • 编辑.podspec文件
    项目文件夹下可用Xcode方式打开,建议里面内容全部删除,将需要配置的信息进行 copy,然后修改。
Pod::Spec.new do |s|
s.name         = "JYWKWebView"
s.version      = "1.0.0"
s.summary      = "WKWebView简单封装"
s.ios.deployment_target = '9.0'
s.homepage     = "https://github.com/CoderJYZhu/JYWKWebView"
s.license      = { :type => "MIT", :file => "LICENSE" }
s.author       = { "某天" => "[email protected]" }
s.source       = { :git => "https://github.com/CoderJYZhu/JYWKWebView.git", :tag => s.version }
s.source_files = "JYWKWebView/*.{h,m}"
s.requires_arc = true
end

下面列出常用配置信息:
s.name:名称,pod search 搜索的关键词,注意这里一定要和.podspec的名称一样,否则报错
s.version:版本号
s.ios.deployment_target:支持的pod最低版本
s.summary: 简介
s.homepage:项目主页地址
s.license:许可证
s.author:作者
s.social_media_url:社交网址,这里我写的微博默认是Twitter,如果你写Twitter的话,你的podspec发布成功后会@你
s.source:项目的地址
s.source_files:需要包含的源文件
s.resources: 资源文件
s.requires_arc: 是否支持ARC
s.dependency:依赖库,不能依赖未发布的库
s.dependency:依赖库,如有多个可以这样写
更多配置信息可以自行百度。
附上官网链接:specs-and-specs-repo
关于资源文件更详细的写法,可以看这篇文章:给 Pod 添加资源文件

source_files:写法及含义建议大家写第一种或者第二种

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

“*” 表示匹配所有文件
“*.{h,m}” 表示匹配所有以.h和.m结尾的文件
“**” 表示匹配所有子目录
  • 验证.podspec文件是否合法
pod lib lint    

下图表示验证通过:


image.png

四、在Github上创建项目release版本

一般也叫做打Tag步骤,可以用命令行操作

配置自己GitHub的开源项目,使用CocoaPods让其支持pod_第6张图片
image.png

配置自己GitHub的开源项目,使用CocoaPods让其支持pod_第7张图片
image.png
配置自己GitHub的开源项目,使用CocoaPods让其支持pod_第8张图片
image.png

点击Publish release即可。创建完成后如图所示:

配置自己GitHub的开源项目,使用CocoaPods让其支持pod_第9张图片
image.png

五、上传代码到CocoaPods

  • 终端cd到项目文件夹下,首先检查文件有效性
pod spec lint

通过验证:


配置自己GitHub的开源项目,使用CocoaPods让其支持pod_第10张图片
image.png
  • 上传到CocoaPods
// pod trunk push xxx.podspec —allow-warnings (验证有警告可以使用 —allow-warnings忽略)
pod trunk push JYWKWebView.podspec --allow-warnings
配置自己GitHub的开源项目,使用CocoaPods让其支持pod_第11张图片
image.png
  • 验证是否上传成功
// 使用pod search XXX搜索
pod search JYWKWebView
配置自己GitHub的开源项目,使用CocoaPods让其支持pod_第12张图片
image.png
  • 如果搜索不到出现下图问题:


    image.png
  1. 执行pod setup其实在你安装CocoaPods执行pod install时,系统会默认操作pod setup,然而由于中国强大的墙可能会pod setup不成功。这时就需要手动执行pod setup指令,如下:
    终端输入:pod setup
    会出现Setting up CocoaPods master repo,稍等几十秒,最底下会输出Setup completed。说明执行pod setup成功。
    如果pod search操作还是搜索失败,如下:
    终端输入:pod search JYWKWebView

  2. 删除~/Library/Caches/CocoaPods目录下的search_index.json文件
    pod setup成功后,依然不能pod search,是因为之前你执行pod search生成了search_index.json,此时需要删掉。
    终端输入:rm ~/Library/Caches/CocoaPods/search_index.json
    删除成功后,再执行pod search。
    执行pod search
    终端输入:pod search JYWKWebView(不区分大小写)
    输出:Creating search index for spec repo ‘master’.. Done!,稍等片刻······就会出现所有带有afnetworking字段的类库。

六、错误信息s.source_files解决办法

验证.podspec文件是否合法过程中遇到过一个问题就是:

image.png

s.source_files  = 'Classes/*.{h,m}'
s.source_files  = 'Classes/DropDownMenu.{h,m}'
s.source_files  = 'Classes'
s.source_files  = 'Classes/**/*.{h,m}'

然后就是无休止的修改s.source_files,上面这几种路径格式我都试过了,也确认路径层次没有问题但是验证就是通不过,还是上图的错误。不知道是不是bug。然后在网上看到别人的路径设置,也跟着试了下,针对我的项目结构,先把s.source_files路径设置为:

s.source_files = "JYWKWebView/JYWKWebView.h"

然后就莫名的验证成功了,并且后续也上传CocoaPods成功了!但是这样上传的项目在后续pod下载的时候只有JYWKWebView.h这一个文件。所以还得重新修改上传。
之后再回头将s.source_files修改回来,将release版本升级为1.0.1、然后在上传CocoaPods:

s.source_files = "JYWKWebView/*.{h,m}"

并且也上传成功了,到这就大功告成了。至于原因没搞清楚,反正就是成功了。

参考文章:
https://www.cnblogs.com/lurenq/p/6785781.html
https://www.cnblogs.com/weiming4219/p/7699699.html
https://blog.csdn.net/conglin1991/article/details/55096422

你可能感兴趣的:(配置自己GitHub的开源项目,使用CocoaPods让其支持pod)