自建cocoaPods库

前言

  • 自制Pod库的流程顺序有很多种,这里根据我们项目的实际情况,来选择了一下的制作流程:
本地新建FrameWork工程
在工程根目录下创建并填写podSpec文件
在宿主工程(或测试工程)中使用development pod方式导入自制pod库
调整pod库,使其可以正常使用
将FrameWork工程上传至git
更新podSpec文件中homepage、source、version等与git相关的参数
检查pod库合法性
上传podSpec文件至Spec Repo并检查是否上传成功
公开podSpec文件(如果需要)

一、安装/更新CocoaPods

  • 开始前,我们先检查当前使用的CocoaPods是否为最新版本,如果不是,则需要升级成为最新版本的CocoaPods
sudo gem install cocoapods -n /usr/local/bin

二、创建FrameWork工程

  • 创建FrameWork工程只是为了承载Pod库所需文件
  • 实际上FrameWork工程文件并不需要进行任何配置,因为最终CocoaPods为我们生成product时所需的配置全部都是在podSpec文件中填写的(这里下一步会讲到)
  • 创建好工程后我们把需要打成pod库的文件丢入工程文件夹内


    image.png

三、创建PodSpec文件

  • 在与工程文件同级的路径下创建与pod库同名的.podspec文件

    image.png

  • 填写podSpec文件,这里图中标红的位置暂时忽略


    image.png
注:文末有podSpec文件中所有参数的解释

四、在调试工程中导入pod库

  • 这里我们使用development pod方式导入自制pod库,在podFile中填写方式如下:
pod 'pod库名',:path=>'.podspec文件所在的文件夹路径'

例:


image.png

五、调试pod库

  • podFile填写完成后执行pod install
  • 成功后,可以在工程下看到我们自制的pod库了,调试它,让它的功能可以正常运行


    image.png

六、上传FrameWork工程至Git

  • pod库可以正常使用后,我们将pod所在的FrameWork工程上传至Git


    image.png

七、更新podSpec文件

  • FrameWork工程上传至Git后,我们需要更新Spec文件中此前被我们忽略掉的几个参数


    image.png

八、检查pod库合法性

  • 进入podSpec文件所在路径执行pod spec lint --allow-warnings
    image.png

九、上传podSpec文件至Spec Repo

  • 进入podSpec文件所在路径执行pod repo push [本地repo源] [.podspec文件] --allow-warning

十、公开podSpec文件(如果需要)

  • 进入podSpec文件所在路径执行pod repo push [本地repo源] [.podspec文件] --allow-warning

    image.png

  • 上传成功后,其他有git权限的用户在pod update后,都可以成功导入我们创建的pod库了

文末 -- podSpec详解

  # podspec 中文注释,注释掉的字段为可选,未注释掉的为必填
  
Pod::Spec.new do |s|  
  
  # ―――Spec基本信息――――――――――――――――――――――――――――――――――――――――――――――#  
  # SDK名字
  s.name         = "TestPodSpec"  
  # SDK版本
  s.version      = "0.0.1"  
  # SDK说明,在搜索SDK时会显示
  s.summary      = "A short description of TestPodSpec."  
  # SDK的描述,DESC是分隔符,写在DESC之间
  s.description  = <<-DESC  
                  描述写在这里
                   DESC  
  # SDK主页,必须是一个能通过网络访问的页面,可以放作者个人页面,公司页面,哪怕放个www.baidu.com也行,只要能访问就可以.
  s.homepage     = "http://EXAMPLE/TestPodSpec"  
  #SDK截图,可以放gif
  # s.screenshots  = "www.example.com/screenshots_1.gif", "www.example.com/screenshots_2.gif"  

  # ―――License信息――――――――――――――――――――――――――――――――――――――――――――――――――――――――――― #
  #license说明
  s.license      = "MIT (example)"  
  # s.license      = { :type => "MIT", :file => "FILE_LICENSE" }  
  
  # ―――作者信息――――――――――――――――――――――――――――――――――――――――――――――#
  # 作者信息,作者名字与邮箱
  s.author             = { "mccree" => "mccree@mc.com" }  
  # Or just: s.author    = "" 
  # 有多个作者的话写这里 
  # s.authors            = { "" => "" }  
  # 社交链接地址
  # s.social_media_url   = "http://twitter.com/"  
  
  # ――― 支持iOS版本信息 ――――――――――――――――――――――――――――――――――――――――――――――――――――――― #  
  # 平台,可以写ios, osx
  # s.platform     = :ios  
  # 支持最低版本
  # s.platform     = :ios, "5.0"  
  #  支持混合平台  
  # s.ios.deployment_target = "5.0"  
  # s.osx.deployment_target = "10.7"  
  # s.watchos.deployment_target = "2.0"  
  # s.tvos.deployment_target = "9.0"  
  
  # ――― 代码仓库支持 git, hg, bzr, svn and HTTP ―――――――――――――――――――――――――――――――――――――――――――――――――――――――――― #  
  # 代码仓库路径,SDK是根据tag号来取代码的,通?;岚裻ag号设成和版本一样  
  s.source = { :git => "http://EXAMPLE/TestPodSpec.git", :tag => "#{s.version}" }  
  
  # ――― 代码文件 ―――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――― #  
  # 代码文件匹配,**指匹配任意文件夹,*.{h,m}指匹配任意.h和.m文件
  s.source_files  = "Classes", "Classes/**/*.{h,m}"  
  s.exclude_files = "Classes/Exclude"  
  # SDK需要暴露的.h文件,默认暴露所有
  # s.public_header_files = "Classes/**/*.h"  
  
  # ――― 资源路径 ―――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――――― #    
  # 指定资源,比如xib,图片等资源都是
  # s.resource_bundles = {
    'XXXKit' => ['XXXKit/Classes/**/*.{storyboard,xib,cer,json,plist}','XXXKit/Assets/*.{bundle,xcassets,imageset,png}']
  }
  
  # ――― 系统库依赖以及静态库―――――――――――――――――――――――――――――――――――――――――――――――――――――――――― #  
  # s.framework  = "UIKit"  
  # s.frameworks = "UIKit", "AnotherFramework"  
  # s.library   = "iconv"  
  # s.libraries = "iconv", "xml2"  
  
  
  # ――― 其他三方库依赖 ――――――――――――――――――――――――――――――――――――――――――――――――――――――――― #  
  # 比如你的SDK依赖AFNetworking,注意这里和podfile中的语法不同在于,这里无法指定其他依赖的具体路径
  # 比如这种写法就不支持 s.dependency 'XMPPFramework', :git => "https://github.com/robbiehanson/XMPPFramework.git", :branch => 'master'
  # s.dependency "AFNetworking", "~> 3.0"  
  
end 
最后编辑于
?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,128评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,316评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事?!?“怎么了?”我有些...
    开封第一讲书人阅读 159,737评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,283评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,384评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,458评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,467评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,251评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,688评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,980评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,155评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,818评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,492评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,142评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,382评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,020评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,044评论 2 352