废话不多说,开始
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 = "https://github.com/NeZha" #主页,随便写
spec.license = "MIT" #许可证类型,我只会MIT,其它的请自行Google
spec.author = { "Ne Zha" => "nezha@fengshen.com" } #作者和邮箱地址,随便写
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号:这里要注意文件路径层级,层级从本地仓库内开始算为第一层,如图:
这个路径就应该写成:
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