CocoaPods发布FrameWork公有库

废话不多说,开始

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

pod命令:

$ pod trunk register EMAIL [YOUR_NAME]

举个例子:

$ pod trunk register [email protected] '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     = "https://github.com/NeZha" #主页,随便写
  spec.license      = "MIT" #许可证类型,我只会MIT,其它的请自行Google
  spec.author       = { "Ne Zha" => "[email protected]" } #作者和邮箱地址,随便写

  spec.platform     = :ios, "8.0" #支持的平台,以及支持的最低系统版本
  spec.source       = { :git => "https://github.com/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

你可能感兴趣的:(CocoaPods发布FrameWork公有库)