(二) CocoaPods的制作(翻译)

简介: 一、前言该篇翻译自http://code.tutsplus.com/tutorials/creating-your-first-cocoapod–cms-24332,说是翻译,其实也不算是直译,删了很多,也加了一些,需要原著直接点进去看。详细的制作流程可以直接查阅官网https://guides.cocoapods.org Making CocoaPods章节。Co

一、前言

该篇翻译自http://code.tutsplus.com/tutorials/creating-your-first-cocoapod–cms-24332,说是翻译,其实也不算是直译,删了很多,也加了一些,需要原著直接点进去看。详细的制作流程可以直接查阅官网https://guides.cocoapods.org Making CocoaPods章节。

CocoaPods的所有命令都可查阅官网https://guides.cocoapods.org/terminal/commands.html,在遇到一个陌生的命令时都可以先查阅一下。

如果你是需要根据此篇制作流程练习,你可以建立一个不同名称的工程,避免与此篇制作的pod冲突导致失败。

笔者根据此篇博客也成功地制作了一个CocoaPod. 所以亲测可用。


二、开始

很明显,制作自己的CocoaPod(或简称为Pod),你需要安装CocoaPods工具,安装CocoaPods的方法可参考这篇博客http://blog.csdn.net/chong_son/article/details/52260806,也可以直接参阅官方网站https://guides.cocoapods.org。只是权限问题,官方的安装会失败,所以还是参考国内的博客安装。安装方法并不难。


三、创建工程

Pod lib 这个命令是在创建Pod过程中一个重要的命令,我们将使用以下的两个命令来完成一些制作并发布CocoaPod的预备工作:

  • pod lib lint 命令是来验证你创建Pod的所需要用到的所有东西是否已经完备
  • pod lib create 命令提供一个快捷方式让你可以创建标准的一系列pod制作所需的文件

打开终端,切换到工作目录,然后执行以下命令

$ pod lib create BlinkingLabel

回车执行后,将会有几个选择需要决定:(亲测的时候,只有四个问题,Cocoapods version 1.0.1)

  • 编程语言。在此例选中的是swift
  • 是否需要穿件Demo工程。一般开源的三方都会提供Demo做参考,回答Yes
  • 测试框架 [Quick / None]。此例选择None
  • 是否需要查看基本的调试。此例选择No

到此在工作目录中就会创建一个CocoaPod工程,完成后它会自动打开


四、提供或者更新所需文件

制作CocoaPod需要提供以下三个文件

  • .podspec :这个文件描述的是制作的这个pod的项目地址、版本号、作者,依赖的框架等信息,这个文件是必备的,可以先参阅一下主流三方的.podspec文件,一看即明。更多关于这个文件的编写参阅https://guides.cocoapods.org/syntax/podspec.html
  • README.md :如果曾经使用过github,你会熟悉一个重要的文件,就是README.md 。这个文件里,可以向使用者介绍这个三方的用法,注意事项,作者等等详细信息,其采用的是Markdown语法编写的。
  • LICENSE :至关重要的一个文件,这个文件是你制作的pod发布的一个“证书”,如果想发布就必须包括这个文件。刚才pod lib create 这个命令已经自动为此例配置了一个MIT 证书。

其实这三者都在创建的时候已经自动生成了,但是其中的某些文件的信息还不完整,是需要自己编写的。

这里写图片描述

1、打开终端,切换到BlinkingLabel目录,执行以下命令验证“是否合格” 。(这是个人理解后想出的描述)

$ pod lib lint BlinkingLabel.podspec

不出意料,会看到以下输出结果:

$ pod lib lint BlinkingLabel.podspec
 -> BlinkingLabel (0.1.0)
    - WARN  | The summary is not meaningful.
    - WARN  | The description is not meaningful.
    - WARN  | There was a problem validating the URL https://github.com/<GITHUB_USERNAME>/BlinkingLabel.

[!] BlinkingLabel did not pass validation.
You can use the `--no-clean` option to inspect any issue.

一大锥warning,说明还是有不合格的地方。

可以看到pod lib lint 是针对着 .podspec 文件,其实可以省去“BlinkingLabel.podspec”,这个命令也会自动去找“BlinkingLabel.podspec”。这些warning,也正是你需要在.podspec 文件中需要补充的东西。

  • summary :摘要说明
  • description:关于该Pod的描述
  • home page :项目的github主页

在这三个字段中根据实际项目填写。(你需要先在github上先创建一个对应的repository)

2、填写完之后可以再pod lib lint 一下,不出意料,输出以下结果:

pod lib lint BlinkingLabel.podspec                                

 -> BlinkingLabel (0.1.0)

BlinkingLabel passed validation.

3、然后将工程推送至github:

git add .
git commit -m “Initial Commit"
git remote add origin https://github.com/<GITHUB_USERNAME>/BlinkingLabel.git // replace <GITHUB_USERNAME> with your github.com username
git push -u origin master

五、添加代码

到此,已经创建好了一个基本的CocoaPod框架,接着就是添加你的三方的源代码。

这里写图片描述

找到ReplaceMe.swift 文件,很明显就是要把这个文件删除,然后替换成自己的源代码文件。

此例中创建一个BlinkingLabel.swift.文件,加入源代码(仅作为简单示例):

public class BlinkingLabel : UILabel {
    public func startBlinking() {
        let options : UIViewAnimationOptions = .Repeat | .Autoreverse
        UIView.animateWithDuration(0.25, delay:0.0, options:options, animations: {
            self.alpha = 0
            }, completion: nil)
    }

    public func stopBlinking() {
        alpha = 1
        layer.removeAllAnimations()
    }
}

为了开发者更好更方便地了解该“框架”的使用,最好在Demo中添加一些示例代码:譬如在BlinkingLabel/Example for BlinkingLabel/ViewController.swift 文件中加入代码:

import UIKit
import BlinkingLabel

class ViewController: UIViewController {

    var isBlinking = false
    let blinkingLabel = BlinkingLabel(frame: CGRectMake(10, 20, 200, 30))

    override func viewDidLoad() {
        super.viewDidLoad()

        // Setup the BlinkingLabel
        blinkingLabel.text = "I blink!"
        blinkingLabel.font = UIFont.systemFontOfSize(20)
        view.addSubview(blinkingLabel)
        blinkingLabel.startBlinking()
        isBlinking = true

        // Create a UIButton to toggle the blinking
        let toggleButton = UIButton(frame: CGRectMake(10, 60, 125, 30))
        toggleButton.setTitle("Toggle Blinking", forState: .Normal)
        toggleButton.setTitleColor(UIColor.redColor(), forState: .Normal)
        toggleButton.addTarget(self, action: "toggleBlinking", forControlEvents: .TouchUpInside)
        view.addSubview(toggleButton)
    }

    func toggleBlinking() {
        if (isBlinking) {
            blinkingLabel.stopBlinking()
        } else {
            blinkingLabel.startBlinking()
        }
        isBlinking = !isBlinking
    }

}

当然此时会报错,找不到BlinkingLabel的声明。因为此时Demo就好比是开发者,它还没有pod install这个BlinkingLabel“框架”,当然找不到。为此,执行以下命令:

> cd Example 
> pod install
Analyzing dependencies
Fetching podspec for `BlinkingLabel` from `../`
Downloading dependencies
Installing BlinkingLabel 0.1.0 (was 0.1.0)
Generating Pods project
Integrating client project

接着打开.xcworkspace工程文件,编译运行成功后将代码推送到远程。

最后编辑README.md文件,向广大开发者介绍该框架。。


六、发布

所谓发布,就是将你制作的pod推至 Spec Repo,这个repo是官方CocoaPods提供的“公共场所”,它的github地址:https://github.com/CocoaPods/Specs,几乎常用的开源三方都是发布到这里的。

发布分三步:

  1. 为项目打上tag,这个tag值最好就是项目的版本号,它要与.podspec文件中的version字段对上。

    之后将tag推送到远程github仓库上。

    > git tag 0.1.0
    > git push origin 0.1.0
    Total 0 (delta 0), reused 0 (delta 0)
    To https://github.com/obuseme/BlinkingLabel.git
    * [new tag]         0.1.0 -> 0.1.0
  2. 验证。此处的验证和上面所述的验证有所不同,这里是验证pod是否具备发布的资格,同样它还是会找.podspec文件,用的命令是pod spec

    > pod spec lint BlinkingLabel.podspec 
    -> BlinkingLabel (0.1.0)
    Analyzed 1 podspec.
    BlinkingLabel.podspec passed validation.
  3. 推送(发布),就是利用CocoaPods的pod trunk命令推送至CocoaPods官方提供的Spec Repo

    > pod trunk push BlinkingLabel.podspec 
    Updating spec repo `master`
    
    Validating podspec
    -> BlinkingLabel (0.1.0)
    
    Updating spec repo `master`
    
     - Data URL: https://raw.githubusercontent.com/CocoaPods/Specs/f7fb546c4b0f80cab93513fc228b274be6459ad2/Specs/BlinkingLabel/0.1.0/BlinkingLabel.podspec.json
     - Log messages:
       - June 29th, 20:40: Push for `BlinkingLabel 0.1.0' initiated.
       - June 29th, 20:40: Push for `BlinkingLabel 0.1.0' has been pushed (1.701885099 s).

这样一来,BlinkingLabel就和其它框架一样,可以通过CocoaPods集成到开发者的项目中工使用了。

可以通过pod search 命令查看pod是否上传成功


七、更新和删除

当需要更新该三方,也就是该pod的版本号时,只需要继续在BlinkingLabel中添加代码,同时Demo中写上一些自己的示例代码,把代码提至远程仓库github上。注意:要把.podspec文件上的版本号改成最新的,记住要先打上tag,然后按照发布一节流程在走一遍即可。

删除则使用pod trunk delete命令,当然官方不建议这么干,因为开发者可能用着你的pod,而且一旦执行,对应的版本号将从此不被上传成功。所以官方建议使用pod trunk deprecate

pod trunk delete NAME VERSION

pod trunk deprecate NAME

CocoaPods的命令集详解都可以查阅官网https://guides.cocoapods.org/terminal/commands.html

目录
相关文章
|
6月前
|
人工智能
AI绘画,Stable Diffusion如何使用中文简体包,黑色页面切换参数http://127.0.0.1:7860/?__theme=dark 两个__,中文包下载和安装
AI绘画,Stable Diffusion如何使用中文简体包,黑色页面切换参数http://127.0.0.1:7860/?__theme=dark 两个__,中文包下载和安装
|
8月前
|
IDE 开发工具 Windows
篇章一 HBuilderX下载与使用
篇章一 HBuilderX下载与使用
204 0
|
Linux C语言 iOS开发
VSCode安装及卸载教程(图文版)
介绍 VSCode 安装教程,也可以点击下面链接进行观看 C语言鹏哥 VSCode 详细安装视频 博客末尾附有 VSCode 百度网盘下载链接 如果对你有帮助,请关注点赞支持博主,后期会出其他相关软件安装教程!!!
397 0
VSCode安装及卸载教程(图文版)
|
图形学
Rhino中文名称犀牛,是一款超强的三维建模工具Rhino 7.9安装教程(所有版本下载安装教程)
Rhino中文名称犀牛,是一款超强的三维建模工具。不过不要小瞧它,它包含了所有的NURBS建模功能,用它建模感觉非常流畅,所以大家经常用它来建模,然后导出高精度模型给其他三维软件使用。
|
编解码 数据建模 Windows
最新版会声会影2023详细图文安装教程
会声会影2023操作简单,使用便捷,创意十足,新增的分屏功能,轨道透明度,镜头平移等功能,让用户的剪辑过程更加流畅,轻松就能制作出令人惊艳的视频作品。它不仅符合家庭或个人所需的影片剪辑功能,甚至可以挑战专业级的影片剪辑软件。适合普通大众使用,操作简单易懂,界面简洁明快。会声会影2023(Corel VideoStudio Ultimate 2023)(亦称绘声绘影)是一款功能强大的视频编辑软件,入手非常简单,可以帮助用户制作优秀的视频内容,支持视频编辑和视频特效等,是一款普及度非常高的视频编辑软件。
859 0
|
Android开发
泼辣修图2023最新版功能介绍及使用教程
看了看后台管理,发现修图软件比较受大家欢迎,所以今天我打算在更新一个修图软件泼辣修图!泼辣修图是一款深受用户喜爱的修图软件,所以今天为大家推荐这款修图APP,经过汉化,所有滤镜和工具都能免费用,无任何的廣搞! 无论你是入门新手还是摄影专家,泼辣修图都可以满足你的一切需求。对于入门新手而言,泼辣修图搭载的先进自动增强工具和富有创意的图像滤镜,可以帮助他们快速雕琢图像的每一个细节。对于摄影专家而言,图层混合、局部调整、曲线工具等等功能则是他们青睐有加的专业特性。
560 0
portraiture2023最新版磨皮插件下载安装教程
期修图中有一个非常关键,而且不可或缺的步骤,那就是磨皮,磨皮的方法有很多种,但最方便快捷就能达到大片级效果的方法,莫过于使用磨皮插件了,Portraiture图像磨皮插件,支持PS CC- CC2023,兼容WIN-MAC系统,portraiture可替代繁琐的手动磨皮,一键就能完成皮肤的去瑕疵、肤色均匀等处理。无论是在实用性上,还是在效果的自然感上,都能达到优秀水准。
420 0
|
编解码
Adobe After Effects2019版本下载安装教程——全版本视频编辑软件
Adobe After Effects2019版本下载安装教程——全版本视频编辑软件
210 0
|
iOS开发 异构计算 MacOS
Premiere Pro2023汉化补丁包免费pr视频编辑软件
Premiere Pro2023中文版简称Pr,pr2023是一款视频编辑软件。 pr2023不仅可以帮助用户对各种视频进行剪辑、旋转、分割、合并、字幕添加、背景音乐等基础的处理,还能帮助用户进行视频颜色校正、颜色分级、稳定镜头、调整层、更改片段的持续时间和速度、效果预设等操作。Premiere有较好的兼容性,且可以与Adobe推出的其他软件相互协作。这款软件广泛应用于广告制作和电视节目制作中。
681 0