制作Cocopods第三方库

先来个 Demo, 点击即可下载

: 建立自己的GitHub仓库

制作Cocopods第三方库_第1张图片

1. 第一个红长方形的是一个README的说明文档,一般第三方库都需要

2. 第二个是license文件,正规的仓库都应该有一个,Pods依赖库对这个文件的要求更严,是必须要有的。因此最好在这里让github创建一个,也可以自己后续再创建。我使用的license类型是MIT。

3. 其他的按照需求自行填写

: clone仓库到本地

1. 可以使用git将将仓库clone到本地

$ git clone https://github.com/KangSky123/WKCategory.git

2. 用SourceTree下载进行管理

3. 下载之后将工程拖进去进行管理

: 导入所需文件

说明:工程中所需的文件一共需要五种文件,1.后缀为.podspec的文件,2.LICENSE文件,3.主类文件,4.README.md,5.demo工程

1. 后缀为.podspec的文件(这一步最重要,也是最容易出错)

pod spec create WKCategory

   (1).首先创建一个.podspec文件(使用命令行进行创建)

  (2).生成之后打开会有很多内容,个人是将全部删除,然后找GitHub上边的第三方的.podspec文件进行复制和修改,具体的各个参数以及内容,请参照http://www.jianshu.com/p/7a82e977281c,下面只列出本例子的.podspec文件内容

Pod::Spec.new do |s|


  s.name        = "WKCategory" 

  s.version      = "0.0.1" 

  s.summary      = "all kinds of categories for iOS develop"

  s.description  = <<-DESC

                      this project provide all kinds of categories for iOS developer 

                   DESC

  s.homepage    = "https://github.com/KangSky123/WKCategory"

  s.license      = "MIT"

  s.license      = { :type => "MIT", :file => "LICENSE" }


  s.author            = { "HuangWenKang" => "[email protected]" }

  s.platform    = :ios

  s.source      = { :git => "https://github.com/KangSky123/WKCategory.git", :tag => "0.0.1" }

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

  s.exclude_files = "Classes/Exclude" 

  s.requires_arc = true


end

 注意: 在填写s.source_files的时候请确定清楚路径是否准确,此路径是主类文件的路径,是相对.podspec文件路径,如果需要引入头文件,则需要s.public_header_files

  (3).编写完成之后,使用 pod lib lint 进行验证,如果有错误,按照提示修改文件内容

git tag -m 'first release' '0.0.1'

git push --tag #推送tag到远端仓库

: tag, 发布一个release版本

: 将工程上传到GitHub

使用git上传或者SourceTree上传(上述的所需文件都要放到该工程中一起上传)

: 发布自己的库描述文件podspeccocoapods

(1). 出现下面的样式之后,说明已经创建成功


制作Cocopods第三方库_第2张图片

: 查找和使用新库

在成功之后使用 pod search WKCategory 无法找到自己的库时候,需要进行下面操作,运行之后会有几分钟的等待时间

pod setup

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

pod search WKCategory

:更新维护podspec

如果有错误或者需要迭代版本,修改工程文件后推送到远端仓库后, 需要修改podspec中的版本号, 并重新打tag上传, 再进行新一轮的验证和发布, 当然, 创建一个演示demo工程供其他开发者下载查看并不会影响我们的pod库.

总结:走完整个流程中,只有在第三步设置.podspec文件中遇到了瓶颈,source_file的路径需要准确,是因为本地工程的路径有错,上传后也出现问题

拓展:

source_file文件路径写法和含义:

"yooweitest/*

"yooweitest/yoowei/*.{h,m}"

"yooweitest/**/*.h"

“*” 表示匹配所有文件

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

“**” 表示匹配所有子目录

你可能感兴趣的:(制作Cocopods第三方库)