代码管理| 创建自己的私有Cocopods库

前言

iOS组件化的实现基本基于cocoapods,如何使用cocoapods创建自己的组件库,是实现组件化的第一要素,下面就创建自己的私有Cocopods库展开实战记录。

本文中引用了很多原文的gif动态图,是因为原作者总结的很好了,但是有些地方我做了补充以及解决了一个很大的使用中的问题,原文链接在本文的文章末尾。

一、创建私有库的索引库

创建索引库文件.gif

创建私有库的索引库,这句话有些绕口,我们分开来看:

1、索引库:存放spec文件的地方,用于索引到代码的位置。 2、私有库:指的是我们真正放置组件代码的地方。 打个比方,索引库就好比指针,私有库就好比对象,指针中存放了对象的地址,通过地址可以找到对象!

我们在创建的这个空的仓库,是用来存放我们自己所有的私有库的  spec  文件,
就如同官方的 https://github.com/CocoaPods/Specs  是用来存放所有官方的  specs  文件一样。

二、将创建的索引库添加到本地cocoapods仓库

添加远程索引库到本地cocoapods.gif

  • 1.cocoapods本地仓库路径 $ ~/.cocoapods/repos
  • 2.在本地添加一个自己的远程索引库 $ pod repo add QinzRepo https://gitee.com/Qinz_323/QinzRepo.git 这个时候需要输入码云账号、密码

上面就是简单的将我们自己创建的索引库放置在cocoapods管理的仓库下,默认情况下是只有一个master仓库,我们常用的SDWebImage,AFNetWoking等的本地索引就在这个仓库中。现在是通过码云来创建自己的仓库,所以要创建一个自己的索引仓库,该仓库下也只是存放各组件的索引文件,不存放代码!

三、创建模板

创建模板.gif

  • 创建模板的命令 $ pod lib create QinzTool 这时会需要回答几个问题,如下图这样回答即可:

通过该命令会自动创建一个模板工程,里面包含我们需要的索引文件,格式为spec,创建完成后,系统会自动打开我们的这个工程。

接下来通过该模板文件来制作我们自己的组件。

四、将我们自己的组件放入指定目录

将组件放入指定文件.gif

模板文件中会看到一个Development pods的文件夹,这个文件夹代表的是本地的组件库,这里我们把Tool文件(也就是我们自己制作的组件)放在指定的文件夹,然后引入到工程中。

(我创建的时候,并没有看到Development 这层文件夹,可以直接把文件拖到 pods/JWJFramework中即可。) 至此,我们的本地第三方组件已经制作完成,现在就可以通过在终端执行pod install 后看看效果了!当然,我们肯定不会局限于本地,接下来就是如何制作线上组件库了!

五、将制作好的组件上传至码云

上传组件至码云.gif

这里你会发现,我又重新创建了一个项目,和我之前创建的索引库项目是不一样的,这个就是真正放置我们封装的代码的地方。这里我们选择导入已有工程,点击创建后会生成一些命令提示,我们找到最下面的三条命令,将本地的模板上传至该仓库!见下图:

上传至码云.gif

  • 1.执行下面三条命令,上传模板文件 $ cd /Users/Qinz/Desktop/QinzTool/QinzTool $ git remote add origin https://gitee.com/Qinz_323/Tool.git $ git push -u origin master
  • 2.将组件的代码上传,上一步只上传了模板文件 $ git add . $ git commit -m ``'初始化'` $ git push -u origin master`

-m '初始化'是提交的备注信息,可以自己根据需要填写,同时可以去网站上时时查看仓库的变化!见下图:

上传代码.gif

六、更改模板文件相关信息

填写模板文件.gif

我们打开Xcode工程,找到.podspec后缀的文件, 更改s.summary,这个是显示在pod search的简短描述:“進无尽的第一个私有库”; s.version是版本号,第一次默认是0.1.0不用修改, 下面再主要修改两个参数 s.homepage 为我们的账号主页地址:https://gitee.com/fangmei s.source中的地址为我们创建组件仓库的地址:https://gitee.com/fangmei/Tool.git 即可!

七、验证spec文件

验证spec文件.gif

$ pod lib lint  --private

这里是对我们的spec文件进行验证,就是是否符合要求!如果这里报错,说明你配置spec文件是有问题的!

八、给版本打一个分支

创建版本分支.gif

此处的 0.1.0 版本号要与 spec 文件的保持一致

  $ git tag    0.1.0
  $ git push  --tags

打分支这一步很重要,直接决定下面的步骤是否能够继续,当我们有版本更新的时候就要更改版本号,这里默认是0.1.0,一定要与之前我们在Xcode中看到的s.version号一致!

九、建立关联

建立关联.gif

 $ pod repo push QinzRepo QinzTool.podspec
 这里QinzRepo 是第二步里面的;
 QinzTool.podspec 是第六步里面的;

通过这一步我们就同步好了远程和本地索引库,到此,私有库已经制作完毕!

十、使用自己的私有库

使用.gif

当我们要使用自己创建的私有库时,要引用我们之前第一步创建的索引仓库地址,也就是指针仓库地址,见上图!

其实这里的使用不像一般第三方库那样,需要加上两个source 才行,否则会报错。 详情爬坑过程见这篇文章:Cocopods| 中使用自己的私有仓库时的一次报错记录


参考文章 http://www.cocoachina.com/ios/20180511/23359.html

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏张首富-小白的成长历程

Linux文件属性详解

文件存储在硬盘上,硬盘的最小存储单位叫做"扇区"(sector)。每个"扇区"的大小为512字节(byte), ,操作系统读取硬盘的时候,不会一个个扇区的读取,...

33820
来自专栏青玉伏案

Git知识总览(二) git常用命令概览

上篇博客我们从 git clone 和 git status 两个命令开始,引出了一系列的git操作命令, 请参见:《Git知识总览(一) 从 git clon...

30280
来自专栏九彩拼盘的叨叨叨

nodejs概要

nodejs是由Ryan Dahl写的。他做nodejs的初衷是为了做一个高性能是web服务器。 为了实现高性能服务器,实现要点是:

22430
来自专栏游戏杂谈

Node.js + Express 构建的订餐系统

Express的版本 – v3.3.3  (安装 $ npm install -g express)

17130
来自专栏草根专栏

Angular CLI 简介

如果您正在使用angular, 但是没有好好利用angular cli的话, 那么可以看看本文.

1.4K110
来自专栏androidBlog

Git 命令行教程及实例教程

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/gdutxiaoxu/article/details/...

14610
来自专栏好好学java的技术栈

手把手从零开始带你学git和GitHub

版本: 想想你平时用的软件,在软件升级之后,你用的就是新版本的软件。你应该见过这样的版本号:v2.0 或者 1511(表示发布时为15年11月),如下图:

11820
来自专栏阮一峰的网络日志

Linux 的启动流程

半年前,我写了《计算机是如何启动的?》,探讨BIOS和主引导记录的作用。 那篇文章不涉及操作系统,只与主板的板载程序有关。今天,我想接着往下写,探讨操作系统接管...

32950
来自专栏屈政斌的专栏

【腾讯云的1001种玩法】centos 7 部署 dotnetcore + Angular2 实践

本文主要讲述了使用腾讯云主机,在centos 7 部署 dotnetcore + Angular2 的实践过程,该项目目前只是用于学习 dotnetcore ...

2.7K10
来自专栏技术视野

使用tail查看并跟踪文本文件的结尾

tail命令是用于查看文本文件末尾的核心Linux实用程序。您还可以使用跟随模式查看实时添加到文件中的新行。tail类似于,用于查看文件的开头

29540

扫码关注云+社区

领取腾讯云代金券