Cocoapods 一般用来管理第三方库,具体可以分为共有库和私有库。通过cocoapos可以快速导入导入需要的功能模块,提升开发效率的同时也提高了编码的质量。在开发过程中,对于封装一个功能模块,多项目中使用(在不考虑耦合度的情况下)需要配置一些系统库和设置。过程不难但很繁琐。那么多个功能模块导入或者模块封装者不在的时候无疑是一种灾难。
一、开源代码的发布
1.在自己的服务器创建代码仓库。
github 开源的库免费,私有的是要收费的。这里以git开源库为例。(不一定要github 其他的代码库也行)
- 从远程库下拉更新 git pull
- 将添加或者修改的文件/代码添加到本地项目目录 git add <filename>
git add task.rtf
git add *
git add .- 提交修改后的文件/代码到本地仓库 git commit -m “备注,描述”
- 从本地仓库推送到远程库 git push
注意: 打tag(指定版本号)主要用于版本控制(必须与podspec中版本一致), git tag -m "1.0.1" 1.0.0 ;
- git tag -m "注释" 0.0.2
- git push --tags
2.注册trunk邮箱 会发带验证链接的邮件到邮箱地址,名称无法修改
pod trunk register 你的邮箱 '英文名’
可查询注册信息。
pod trunk me
3.创建.podspec文件
注意:会在当前目录下生成 podName.podspec文件,里面有非常多的注释,大部分都是无用的。建议删除内容,直接使用其它成功提交的podspec文件修改。
pod spec create podName
.podspec文件详情:
Pod::Spec.new do |s|
s.name = "podName" #名字
s.version = "0.1.0" #版本号
s.summary = "Custom Category" #简短的介绍
s.homepage = "https://github.com/1551715165/PXLNetWork" #主页,这里要填写可以访问到的地址,不然验证不通过
s.license = "MIT" #开源协议
s.author = { "fqzl" => "1551715165@qq.com" } #作者信息
s.platform = :ios, "10.0" #支持平台及版本
s.source = { :git => "https://github.com/1551715165/PXLNetWork.git", :tag => s.version } #这里的tag是github上的版本 建议与cocoapods上版本对应
s.source_files = "podName//" #代码源文件地址
s.requires_arc = true #项目是否使用 ARC
s.resources = "resource//" #资源文件(.xib,.png, bundle等)
s.dependency "JSONKit", "~> 1.4" #当前依赖库,pod install时会自动下载该库(注意:没有 '=' 符号 )
这里要特别说一下
s.source_files = "podName/*/" 表示podName目录及其子目录下所有文件,如果有多个目录下则用逗号分开,如果需要在项目中分组显示,这里也要做相应的设置。这里的路径对应git仓库和本地验证时用到的路径。
注意点:
- 本地验证时(没有语法错误):会自动在"/Users/用户/Library/Caches/CocoaPods/Pods/External/.podspec文件名/035cb9aa62b9d49f904fad1119b83da4-aebfe"文件目录下查询"podName/*/"。 如果路径不对,终端会提示 The
source_files
pattern did not match any file. 这时候应该查询有没有你的podName文件夹,没有就自己新建一个。- git仓库路径:上面提到的是本地验证,验证通过就可以发布了。但是git上如果没有与之对应的文件路径,pod update 下来的库你会发现没有文件。
这里再说一下#.subspec 这个属性
s.public_header_files = 'Expand/NetWork/.h'
ss.subspec 'DownLoadTool' do |sss|
sss.source_files = 'Expand/NetWork/NetWorkDownloadTool/.{h,m}'
sss.dependency 'PXLNetWork/NetWork/RequestTool'
end
.source_files 在导入xcode时只会导入文件,文件夹会忽略掉。使用.subspec会创建文件夹,在.subspec文件里的代码文件如果要用到父subspec里的代码.h文件,需要在父subspec里面用s.public_header_files声明。(dependency在. subspec 还可以依赖别的subspec # podspec名/subspec名)
- 发布
pod spec lint podName.podspec --allow-warnings #检验pod是否有警告
pod trunk push podName.podspec --allow-warnings #私有pod时请跳过此步骤)
发布中出现的问题终端都会提示的很清楚,这里要注意的是:最好不要用文本编辑打开 podName.podspec,这可能会导致文件转码异常。(我这里是xcode打开 其他的开发软件也是可以)
发布过程中的一些注意细节
注意:发布成功后没有搜索到自己的开源项目
执行pod setup
终端输入:pod setup
会出现Setting up CocoaPods master repo,稍等几十秒,最底下会输出Setup completed。说明执行pod setup成功。
如果pod search操作还是搜索失败,如下:
终端输入:pod search [podname]
输出:Unable to find a pod with name, author, summary, or descriptionmatching [podname] 这时就需要继续下面的步骤了。
删除~/Library/Caches/CocoaPods目录下的search_index.json文件
pod setup成功后,依然不能pod search,是因为之前你执行pod search生成了search_index.json,此时需要删掉。再搜索一下就可以了。
二、Cocoapods Podfile文件使用注意
1.有一些库编译时候会有警告。但是作为一个有洁癖的人呢不想看见这些。可以在platform :ios, ‘x.0’的后面加入这句
inhibit_all_warnings!
2.但是有一个神库ReactiveCocoa。当你关闭所有警告的时候。它就编译不过了。可急坏了。其实很简单对他单独设置打开编译警告就好了
pod 'ReactiveObjC', '~> 3.0.0', :inhibit_warnings => true
总结:
这里只是把具体的流程和比较常见的错误走了一遍,希望这篇文章能帮大奖学习和了解CocoaPods。