这两天学习了如何添加自己封装的代码到Cocoapod中

以下是我这两天遇到的各种坑:

旧的方法:  http://my.oschina.net/u/727843/blog/392784

这个看看可以大概了解以前的cocoapod是怎么添加新库的.

新的方法: http://yulingtianxia.com/blog/2014/05/26/publish-your-pods-on-cocoapods-with-trunk/

上述地址是非常详细的介绍了如何添加.

现在记录需要注意的地方:

1. 必须需要翻墙,要不然连不上cocoapod 的 trunk 服务器.

2. 如果你执行了一个命令,半天没有反应,注意看看 是不是 把英文的单引号, 输入成了双引号 或者中文的双引号

3. podspec 文件中,记得所有的单双引号都是英文的,如果出现中文, 会报语法错误,并且是错误的提示会指示到下一行.我是找了半天.

4. 关于版本号, 文章(新的方法网址)中有一处是错误的,估计是trunk 变化了.

我用的podspec是:

s.name = 'RXCoreText'
s.version = '0.1' 

在给git 添加tag的方法:

git tag '0.1'
git push --tags
git push origin master

实际上git的版本是 0.1 而不是v0.1

所以用:

pod trunk push RXCoreText.podspec --verbose

会出现:

warning: Could not find remote branch v0.1 to clone.

fatal: Remote branch v0.1 not found in upstream origin

意思是发现不了版本号,

因此需要把上述git代码变成  v0.1(注意大小写):

git tag 'v0.1'
git push --tags
git push origin master

原因是在podspec文件中:

tag => "v#{s.version}"

注意前面的那一个字母的v.

这样就可以正确的 pod trunk push 了!

5.  出现这个错误:  NoMethodError - undefined method `length' for nil:NilClass

可能的原因是 podspec文件,少了一些字段:

 s.name     = "RXVerifyButton"
s.version = "0.2"
s.license = "MIT"
s.summary = "RXVerifyButton is a simple SMS count down"
s.homepage = "https://github.com/xzjxylophone/RXVerifyButton"
s.author = { 'Rush.D.Xzj' => 'xzjxylophoe@gmail.com' }

6.  提交失败:

did not pass validation, due to 1 warning (but you can use `--allow-warnings` to ignore it).

其中之一的原因是:s.description 的长度 小于 s.summary

7. 源码中有.a文件的:

s.vendored_libraries '*.a'

8. 需要引用系统库的:

s.libraries  'z.1', 'sqlite3'

注: 如果系统.a文件是lib开头的, 那么就直接省略掉,并且省略最后的.a

我在pod trunk的时候,  少了一个  s.summary就会出现上述错误.

如果大家发现上述的错误, 可以找一个正确的podspec,然后一个字段一个字段的对比再试一试.

目前就发现如上的几个坑. 欢迎大家各种补充.

如何添加自己封装的代码到Cocoapod的更多相关文章

  1. Github 大牛封装 Python 代码,实现自动发送邮件只需三行代码

    *注意:全文代码可左右滑动观看 在运维开发中,使用 Python 发送邮件是一个非常常见的应用场景.今天一起来探讨一下,GitHub 的大牛门是如何使用 Python 封装发送邮件代码的. 一般发邮件 ...

  2. 微信公众平台中添加qq在线聊天代码

    微信公众平台是个不错的媒体,可以和你的小伙伴们即时交流,但你的小伙伴们是用手机上的微信,打字自然就慢了:有人说用微信网页版,那个也不习惯,再说也不一定所有人都知道网页版微信.(2014.01.22更新 ...

  3. netbeans中给jpanl添加背景图片制定代码的理解——匿名内部类继承父类

    此测试是为了仿照在netbeans中给jpanl添加背景图片的制定代码的执行过程 在JpDemo中定义了个Car类的数据类型,但在给其赋值对象时使用了匿名内部类,继承了Car类,是其子类,并重写了父类 ...

  4. 用JS添加文本框案例代码

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  5. 网络传输 buf 封装 示例代码

    网络传输 buf 封装 示例代码 使用boost库 asio // BufferWrapTest.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h&quo ...

  6. 树莓派(Raspbian系统)中使用pyinstaller封装Python代码为可执行程序

    一.前言 将做好的Python软件运行在树莓派上时,不想公开源码,就需要对文件进行封装(或称打包),本文主要介绍使用pyinstaller封装Python代码为可执行程序. Python是一个脚本语言 ...

  7. css代码添加背景图片常用代码

    css代码添加背景图片常用代码 1 背景颜色 { font-size: 16px; content: ""; display: block; width: 700px; heigh ...

  8. angularjs中向html页面添加内容节点元素代码段的两种方法

    第一种方式:原生JS向html页面添加内容节点元素代码段: <!DOCTYPE html> <html> <head> <meta charset=" ...

  9. [PHP] JQuery+Layer实现添加删除自定义标签代码

    JQuery+Layer实现添加删除自定义标签代码 实现效果如下: 实现代码如下: <!doctype html> <html> <head> <meta c ...

随机推荐

  1. 设备像素,设备独立像素,CSS像素

    之前学了移动端的开发对设备像素.设备独立像素.CSS像素弄得不太清楚,所以趁周末的时间查了一下,稍加整理 一些概念 在进行具体的分析之前,首先得知道下面这些关键性基本概念. CSS像素 CSS像素是W ...

  2. 利用Unity3D实现多平台增强现实网络游戏的一种方案

    这几天去厦门参加了VALSE2017会议,对于其中某个环节展示的有关增强现实游戏的部分印象深刻.因为前两年一度沉迷于利用各类引擎开发游戏,所以也曾经以Pokemon GO为模板开发过一款多平台增强现实 ...

  3. Kafka官方文档

    Apache Kafka是 一个分布式消息发布订阅系统.它最初由LinkedIn公司基于独特的设计实现为一个分布式的提交日志系统( a distributed commit log),,之后成为Apa ...

  4. C# 在iis windows authentication身份验证下,如何实现域用户自动登录

    前言: 该博文产生的背景是有个项目在客户那部署方式为iis windows身份验证,而客户不想每次登录系统都要输入帐号和密码来登录. 因此需要得到域用户,然后进行判断该用户是否可以进入系统. 解决方法 ...

  5. Github开源:Sheng.RabbitMQ.CommandExecuter (RabbitMQ 的命令模式实现)

    [Github]:https://github.com/iccb1013/Sheng.RabbitMQ.CommandExecuter Sheng.RabbitMQ.CommandExecuter 是 ...

  6. 使用fontawesome图标

     我每次找图标时都是在阿里的开源图标库中找的,但是使用起来不是很方便.而我发现了fontawesome之后,觉得实在不错,所以分享给大家.  这是一些参考的文档. fontawesome下载与使用介绍 ...

  7. PHP实现二维数组排序(按照数组中的某个字段)

    亲测可行

  8. RNN的介绍

    一.状态和模型 在CNN网络中的训练样本的数据为IID数据(独立同分布数据),所解决的问题也是分类问题或者回归问题或者是特征表达问题.但更多的数据是不满足IID的,如语言翻译,自动文本生成.它们是一个 ...

  9. (转)static 变量

    一. static 变量 static变量大致分为三种用法1. 用于局部变量中,成为静态局部变量. 静态局部变量有两个用法,记忆功能和全局生存期.2. 用于全局变量,主要作用是限制此全局变量被其他的文 ...

  10. React入门---可复用组件-10

    主要对props更多重要的特性进行学习; 还是用之前代码, index.js代码为: var React = require('react'); var ReactDOM = require('rea ...