美文网首页iOS程序员iOS程序猿
CocoaPods发布FrameWork公有库

CocoaPods发布FrameWork公有库

作者: ChinaChong | 来源:发表于2019-08-14 12:03 被阅读4次

    之前写过一篇幼儿园版的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     = "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号:这里要注意文件路径层级,层级从本地仓库内开始算为第一层,如图:

    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公有库

        本文链接:https://www.haomeiwen.com/subject/showjctx.html