创建只有自己能Pod的私有库

作者: mimi不是米 | 来源:发表于2016-09-01 16:49 被阅读814次

      对于iOS开发者来说,Cocoapods无疑是一个非常好用的三方库管理工具,在开发过程中,我们也会使用到许多优秀的三方库。有时候我们也需要将自己的东西封装起来并重复利用,但是又不想像Cocoapods上一样让别人用,这时我们就需要建立自己的私有库。

      想要上传自己的私有库,需要先弄懂Cocoapods的原理及目录结构。Cocoapods一共分为两块,即CocoapodsSpecs,Specs实际上是一个目录容器,所有的三方库的podspec文件都在里面,那么podspec文件又是什么呢,podspec文件就相当于每一个三方库的介绍文件,包含名字、版本、以及三方库的下载地址等,步骤三会详细介绍。

      使用过cocoa pods的同学在本地都会有一个.cocoapods/repos文件夹,这个文件夹就是在使用cocoa pods时自动从Specs上clone到本地的,即路径~/.cocoapod/repos,进入本地看看目录结构:

    repos->master->Specs->[Name]->[Version]->[Name].podspec

      没错,这个是公有的三方库的目录,我们做私有库,就是要模仿公有库的结构目录,建立一个自己的Spec的私有仓库来维护,这个仓库可以是私有也可以是公开。总的来说,我们需要维护的东西有两个,一个是私有的Specs目录,一个是我们需要上传的三方库。

    一、创建私有的Specs目录

    在远端建一个仓库,命名为MySpecs,把仓库clone到本地,把公有Specs里面的CocoaPods-version.yml文件拷贝到里面,并建立一个名为“Specs”的文件夹,(文件夹里面可以放一个无关的小文件,要是是空文件夹推到远端可能会被忽略),然后把东西推动远端仓库,私有Specs创建完成。如图:

    二、将远端的私有Specs仓库clone到本地.cocoapods目录下

    $ pod repo add MySpecs https://xxxx@bitbucket.org/xxxx/Myspecs.git 

    在终端执行上述命令,记得将仓库地址改正。执行成功的话,在本地~/.cocoapods/repos路径下就能发现,多了一个MySpec的文件夹。

    三、创建pod spec文件

    我必须说这一步尤为重要

    我必须说这一步尤为重要

    我必须说这一步尤为重要

    重要的事情说三遍。

    准备工作:1、将需要作为三方库的所有文件整理在工程的一个文件夹下(为后续方便),并上传至远端。

                    2、打开终端cd 到本地工程下。

    执行命令:

    $ pod spec create [Name] https://xxxx@bitbucket.org/xxxx/xxxx.git

    注:其中Name是三方库的名字,地址是作为三方库的工程的远端地址。

    完成后在当前目录下回生成一个叫做[Name].podspec的文件。打开这个文件(建议用sublime打开,sublime很好用,另外sublime的负责人看到了记得打赏广告费,谢谢!)里面注释相当详细,我这里列举几个重要的:

    s.name        = "xxxx"     #三方库名字

    s.version      = "0.0.1"     #版本号,建议从0.0.1开始(官方的版本号是不能删除和向下修改的,只能递增,但私有库是我们自己维护的,所以可以随意修改)

    s.summary      = "xxxxxxxx"    #三方库总结

    s.description  = "xxxxxxx"       #三方库描述

    s.homepage  = "https://xxxxxxx"       #主页信息(填写项目仓库的地址即可)

    s.license      = "MIT"  #开源协议,一般填MIT(注:.podspec

    文件同目录下必须要有一个MIT开源协议文件,如果没有,去github上别人的目录下随便拷贝一个)

    s.author            = { "xxxxxx" => "xxxxxx@163.com" }#作者姓名、邮箱,不用我说了吧

    s.platform    = :ios, "7.0" #支持的系统版本

    s.source      = { :git => "https://xxxx@bitbucket.org/xxx/xxx.git", :tag => "0.0.1" }#资源地址,很重要,pod install的时候根据这个地址去下载三方库,另外为避免麻烦,版本号必须与s.version中的版本号一致。

    s.source_files = ""#这个很重要,指定资源文件,前缀就是.podspec文件当前路径,只用写之后的路径,如Class/*是指Class文件夹下的所有文件,但不包括子文件夹里面的文件、Class/**/*是指包含所有Class文件夹下的文件,包括子文件、Class/**/*.{h,m}是指包含所有Class文件夹下的后缀为.h或.m的文件,当然也可以指定文件。

    s.requires_arc = true#是否支持arc

    #######以下的为可选

    #s.resource  = "icon.png"#资源文件,包括图片和xib文件

    # s.dependency "JSONKit", "~> 1.4"#需要依赖的三方库

    #s.framework  = "SomeFramework"#需要依赖的框架

    #s.public_header_files = ''#公开的头文件,如果不没公开,用户在用的时候可能引不到响应的头文件

    s.subspec 'subFolder' do |ss|

    ss.source_files = 'Class/xxx/**/*.{h,m}'

    ss.public_header_files = "Class/xxx/**/*.{h}"

    end#这个是子依赖库,因为如果我们只是用s.source_files来指定文件,那么用户在pod下来之后所有的文件都在同一个目录下,没有子文件夹,如果想要分下类,用s.subspec,每一个subspec可以分一个子文件夹,但是记得一定要将.h文件通过ss.public_header_files公开,不然有可能会找不到头文件。

    差不多这些重要的,可以根据库的复杂度酌情修改,然后保存。

    如有不明白的可以和我讨论,或者去参考其他的如:AFNetworking等的podspec文件。

    四、验证

    打开终端,cd到.podspec文件的目录下,使用命令:

    $ pod lib lint

    如果有错,按照错误修改podspec文件,如果通过,那么恭喜你完成一大部分了。

    当然为了验证你的文件路径指定对不对,我们可以做一个测试,找一个新工程,在Podfile文件中加入

    pod '[Name]', :podspec => '/Users/xxxx/Desktop/xxx/xxx.podspec'

    注:[Name]为pod spec中的s.name,必须一致,后面的路径为本地pod spec文件的路径。

    然后打开终端cd到当前Podfile目录下执行

    pod install

    pod install --no-repo-update

    第二条命令是不更新官方Specs至本地,速度要比第一条快。

    执行完成之后,打开工程看看Pods下的三方库的结构是不是跟你想象的一样,并可以测试能不能用。

    五、向Specs远端提交.podspec文件

    通过验证后,给当前代码打上tag,建议tag和版本号一致,并推送到远端(官方的tag是不能向下修改的)

    $ git tag '0.0.1

    $ git push origin --tags

    将tag推送到远端之后,向自己的私有库提交podsepc文件:

    $ pod repo push MySpecs [Name].podspec

    如果提交成功,这时候去到~/.cocoapods/repo/MySpecs文件夹下就发现多了一个文件夹,正是你刚刚创建的三方库。

    到这里,恭喜你的私有库创建完成。

    六、使用

    不出意外,这个时候,你去终端pod search 你的三方库名字,就能搜到(如果你的名字和官方Specs里面的某个三方库名字一样的话将会搜不到),使用的时候在Podfile中加入两个Specs源即:

    官方源:

    source 'https://github.com/CocoaPods/Specs.git'

    私有源:

    source 'https://xxxxx@bitbucket.org/xxxxx/Myspecs.git'#即你的私有源仓库地址

    当然,你也可以指定地址

    pod 'xxxx', :git =>'https://xxxx@bitbucket.org/xxxx/xxxx.git'

    这里的地址是你的三方库的远端地址。二选一都行,为了避免冲突,建议用第二种。

    把自己踩过的坑记录下来,希望对正在研究的同学有帮助。

    相关文章

      网友评论

      • 其实也没有:如果我这个私有源 引用 了另一个私有源 我怎么配置
      • b96acac40a08:做到pod search 时
        Unable to find a pod with name, author, summary, or descriptionmatching
        mimi不是米:@欲狼 能pod下来吗?
        b96acac40a08: @mimi不是米 有啊,远端也有啊,就是搜不到。。。。
        mimi不是米:@欲狼 去本地~/.cocoapods/repos/MySpec/Specs文件下看看是否有你自己的私有库
      • 段帅帅:写的很好啊 支持

      本文标题:创建只有自己能Pod的私有库

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