CocoaPods发布FrameWork公有库

作者 : 开心源码 本文共2862个字,预计阅读时间需要8分钟 发布时间: 2022-05-13 共159人阅读

之前写过一篇幼儿园版的CocoaPods相关文章,最近又需要用到CocoaPods发布公有库。然而这次是发布公司的SDK,也就是自己写的Framework。坑还是踩了几个的,本次采用干货形式,不上截图了,就当做高中水平了。

废话不多说,开始

1.首先注册一个CocoaPods的账户

pod命令:

$ pod trunk register EMAIL [YOUR_NAME]

举个例子:

$ pod trunk register nezha@fengshen.com 'Ne Zha'

2.创立Git仓库,需要带上MIT许可。

Git的仓库可以是GitHub这种公共的源,也可以是你们自己搭建的,像我这种普通玩家还是建一个GitHub的仓库来的实在。

3.把刚刚创立的仓库克隆到本地(高级->master)

对于Git,我还是喜欢用sourcetree,看得见的才放心。

4.把Framework拖到本地仓库文件夹中

拖进来之后,sourcetree就会提醒你本地有变动。而后就是提交(Commit)。

5.打标签,推送到远程仓库

打标签就是在push之前,用sourcetree给本次升级打一个tag。这个tag很重要,tag建议使用1.2.3这样的版本号,由于这个tag就是CocoaPods以后需要使用的版本号。

6.创立podSpec文件

最重点的就是这个podSpec文件,这里面记录着你Pod所有的信息。

提醒:我是cd到本地仓库文件夹做的操作。我的本地仓库中把MIT Licence 文件也克隆了下来,所有在我的本地仓库文件夹中是有licence文件的,假如没有这个文件会报警告,但是不影响。

pod命令:

$ pod spec create xxx

举个例子:

$ pod spec create NeZha

重点

podSpec文件

Pod::Spec.new do |spec|  spec.name         = "NeZha"  spec.version      = "1.2.3" #此处要与上传到Git的tag一致  spec.summary      = "This is my test pod." #摘要,随意写  spec.homepage     = " NeZha" #主页,随意写  spec.license      = "MIT" #许可证类型,我只会MIT,其它的请自行Google  spec.author       = { "Ne Zha" => "nezha@fengshen.com" } #作者和邮箱地址,随意写  spec.platform     = :ios, "8.0" #支持的平台,以及支持的最低系统版本  spec.source       = { :git => " NeZha.git", :tag => "#{spec.version}" }  spec.source_files = "NeZha.framework/Headers/*.{h}" #001号 坑  spec.pod_target_xcconfig = { 'OTHER_LDFLAGS' => '-lObjC' } #002号 坑  spec.ios.vendored_frameworks = 'NeZha.framework' #003号 坑  spec.requires_arc = true #能否需要ARC  spec.frameworks = "Foundation", "UIKit" #依赖多个系统framework  spec.libraries = 'iconv', 'xml2' # 004号 坑  spec.dependency "AFNetworking", "3.2.1" #依赖三方的库,假如想要增加多个依赖,不可以用逗号隔开,应该依赖一个写一句。  spec.dependency "FMDB", "2.7.5"end
坑点:

001号:这里要注意文件路径层级,层级从本地仓库内开始算为第一层,如图:

xxoo.png

这个路径就应该写成:

spec.source_files = "NeZha.framework/Headers/*.{h}"

002号:我的SDK里用到了Category,所以手动集成时要在Other Linker Flags中增加-ObjC。但是我在CocoaPods中一直找不到怎样自动设置这个工程配置,后来也是在CocoaPods官网一个一个实验出来的。

spec.pod_target_xcconfig = { 'OTHER_LDFLAGS' => '-lObjC' }

003号:这个地方就是和我以前只上传.h .m 源码的最大区别。Framework讲究竟不是文件,是一个文件夹,而且是一个特殊的文件夹。想要Framework正常使用,必需用到这句。而且这里可以用逗号隔开,增加多个Framework,比方:

spec.ios.vendored_frameworks = 'NeZha.framework', 'AoBing.framework', 'TaiYi.framework'

004号:设置依赖多个系统的library。设置library有个小坑,正常在Xcode里我们见到的一般都叫libz.tbd、libxml2.tbd,但是这里不能这么写,lib要去掉,.tbd也要去掉,只留下 z 或者者 xml2 这个名字就行。

7.验证podspec文件语法

pod命令:

pod spec lint xxx.podspec

举个例子:

pod spec lint NeZha.podspec

这一步,Error不能忽略(你也过不去)必需处理。Warning可忽略。假如出错了却看不到具体错误信息,可以在命令后面加--verbose,比方:

pod spec lint NeZha.podspec --verbose

这样就会有详细的debug信息打印出来。

8.发布到CocoaPods

pod命令:

pod trunk push xxx.podspec

举个例子:

pod trunk push NeZha.podspec

发布成功会提醒你Tell your friends,而后还有个小火箭??。

另外

有个特殊情况,比方你的Framework强依赖AFNetworking,即在文件中import了AFN的头文件之类的操作,但是作为一个不为别人添麻烦的Framework应该学会照顾自己。也就是说当有些人的工程中采用手动方式集成了AFN,而你的Pod依赖了AFN,这样Pod中有一份AFN,主工程中有一份AFN,就会造成重复导入的情况。

那么,假如我们不在podSpec中依赖AFN是不是即可以了呢。答复是:一般情况下不行。你会发现假如你直接pod spec lint去检查语法,会报错,找不到文件。也就是说当你trunk push的时候你也是push不了的。由于CocoaPods上传时会先调用xcodebuild,检查一遍文件能否可以正常编译。

处理办法就是:

pod trunk push xx.podspec --skip-import-validation

跳过import的检查就行了

再另外

一般刚刚push到CocoaPods的新库,此时你pod search 是搜不到的,执行下列命令:

pod setup
rm ~/Library/Caches/CocoaPods/search_index.json
pod search NeZha

说明
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » CocoaPods发布FrameWork公有库

发表回复