编写一个最简单的例子

1. 建好如下文件夹

注意:lib目录下必须有个和你gem名字一样的rb文件。

  1. $ cd hola
  2. $ tree
  3. .
  4. ├── hola.gemspec
  5. └── lib
  6. └── hola.rb

2. 编写代码

. hola.rb

  1. % cat lib/hola.rb
  2. class Hola
  3. def self.hi
  4. puts "Hello world!"
  5. end
  6. end

.hola.gemspec

  1. % cat hola.gemspec
  2. Gem::Specification.new do |s|
  3. s.name        = 'hola'
  4. s.version     = '0.0.0'
  5. s.date        = '2010-04-28'
  6. s.summary     = "Hola!"
  7. s.description = "A simple hello world gem"
  8. s.authors     = ["Nick Quaranto"]
  9. s.email       = 'nick@quaran.to'
  10. s.files       = ["lib/hola.rb"]
  11. s.homepage    =
  12. 'http://rubygems.org/gems/hola'
  13. end

这里面可以设置很多属性。

上面字段的意思,比较简单。相信大家都能理解。

3.编译生成gem

  1. % gem build hola.gemspec
  2. Successfully built RubyGem
  3. Name: hola
  4. Version: 0.0.0
  5. File: hola-0.0.0.gem
  6. % gem install ./hola-0.0.0.gem
  7. Successfully installed hola-0.0.0
  8. 1 gem installed

4.测试使用

  1. % irb
  2. >> require 'hola'
  3. => true
  4. >> Hola.hi
  5. Hello world!

注意:在ruby 1.9.2之前到版本里面,需要先require 'rubygem',才能使用我们写的gem.

5.发布到rubygems网站

  1. $ curl -u tom https://rubygems.org/api/v1/api_key.yaml >
  2. ~/.gem/credentials
  3. Enter host password for user 'tom':

设定完之后发布

  1. % gem push hola-0.0.0.gem
  2. Pushing gem to RubyGems.org...
  3. Successfully registered gem: hola (0.0.0)

发布成功。

这样任何一个人都可以使用你写的gem了。

稍微复杂的rubygem例子

上面的例子只有一个ruby文件,一般gem应该没有这么简单的。

下面说下有多个ruby文件该怎么写。

1. 目录结构

多了个hola目录和translator.rb文件

  1. % tree
  2. .
  3. ├── hola.gemspec
  4. └── lib
  5. ├── hola
  6. │   └── translator.rb
  7. └── hola.rb

2. 代码

lib/hola/translator.rb
  1. % cat  lib/hola/translator.rb
  2. class Hola::Translator
  3. def initialize(language)
  4. @language = language
  5. end
  6. def hi
  7. case @language
  8. when :spanish
  9. "hola mundo"
  10. else
  11. "hello world"
  12. end
  13. end
  14. end
lib/hola.rb
  1. % cat lib/hola.rb
  2. class Hola
  3. def self.hi(language = :english)
  4. translator = Translator.new(language)
  5. translator.hi
  6. end
  7. end
  8. require 'hola/translator'

.hola.gemspec

  1. % cat hola.gemspec
  2. Gem::Specification.new do |s|
  3. s.name        = 'hola'
  4. s.version     = '0.0.0'
  5. s.date        = '2010-04-28'
  6. s.summary     = "Hola!"
  7. s.description = "A simple hello world gem"
  8. s.authors     = ["Nick Quaranto"]
  9. s.email       = 'nick@quaran.to'
  10. s.files       = ["lib/hola.rb", "lib/hola/translator.rb"]
  11. s.homepage    =
  12. 'http://rubygems.org/gems/hola'
  13. end

其他步骤和上面一样了。很简单吧!

最后说下怎么写个 gem包含可执行文件的例子。

这个也很简单。像rake就是典型的包含可执行文件的gem.

1. 在刚才工程目录下建个bin文件夹

生成可执行文件,并且修改权限为可运行。

  1. % mkdir bin
  2. % touch bin/hola
  3. % chmod a+x bin/hola

2. 修改可执行文件内容
bin/hola

  1. #!/usr/bin/env ruby
  2. require 'hola'
  3. puts Hola.hi(ARGV[0])

测试下

  1. % ruby -Ilib ./bin/hola
  2. hello world
  3. % ruby -Ilib ./bin/hola spanish
  4. hola mundo

3 .最后修改gemspec

  1. % head -4 hola.gemspec
  2. Gem::Specification.new do |s|
  3. s.name        = 'hola'
  4. s.version     = '0.0.1'
  5. s.executables << 'hola'

其他就和上面一样了。很简单吧。

------------------------------------------------------------------------------

什么是RubyGems?

RubyGems是一个方便而强大的Ruby程序包管理器,Ruby的第三方插件是用gem方式来管理,非常容易发布和共享,一个简单的命令就可以安装上 第三方的扩展库。特点:能远程安装包,包之间依赖关系的管理,简单可靠的卸载,查询机制,能查询本地和远程服务器的包信息,能保持一个包的不同版本,基于 Web的查看接口,能查看你安装的gem的信息。

安装RubyGems

官方站点 http://rubygems.org/pages/download

下载地址:http://rubyforge.org/frs/?group_id=126

Windows 用户直接下载.zip压缩包,解压缩,从CMD提示窗口下进入 setup.rb所在目录, 运行 ruby setup.rb 即可安装。

Ruby1.9.1 以后的版本自带RubyGems,直接在CMD窗口下输入指令 gem update --system 升级到最新版即可。

gem包的安装方式:

RubyGems.org 是官方的Gem托管中心,RubyGems就是从这里远程下载gem包的。RubyGems 将所有的gem包 安装到 /[ruby root]/lib/ruby/gems/[ver]/ 目录下,这其中包括了cache、doc、gems、specifications 4个目录,cache下放置下载的原生gem包,gems下则放置的是解压过的gem包。当安装过程中遇到问题时,可以进入这些目录,手动删除有问题的 gem包,然后重新运行 gem install [gemname] 命令即可。

RubyGems命令详解:

我们以目前最新的 rubygems 1.8.16 为例:

# 查看RubyGems软件的版本
gem -v

# 更新升级RubyGems软件自身
gem update --system

# 更新所有已安装的gem包
$ gem update

# 更新指定的gem包
# 注意:gem update [gemname]不会升级旧版本的包,可以使用 gem install [gemname] --version=[ver]代替
$ gem update [gemname]

# 安装指定gem包,程序先从本机查找gem包并安装,如果本地没有,则从远程gem安装。
gem install [gemname]

# 仅从本机安装gem包
gem install -l [gemname]

# 仅从远程安装gem包
gem install -r [gemname]

# 安装gem包,但不安装相关文档文件
gem install [gemname] --no-ri --no-rdoc

# 安装指定版本的gem包
gem install [gemname] --version=[ver]

# 删除指定的gem包,注意此命令将删除所有已安装的版本
gem uninstall [gemname]

# 删除某指定版本gem
gem uninstall [gemname] --version=[ver]

# 查看本机已安装的所有gem包
gem list

# 列出远程RubyGems.org 上有此关键字的gem包(可用正则表达式)
gem list -r keyword

# 列出远程RubyGems.org 上所有Gmes清单,并保存到文件。
gem list -r > remote_gem_list.txt

#查看所有gem包文档及资料
gem server

#显示RubyGem使用帮助
gem help

#列出RubyGem命令一些使用范例
gem help example

更多命令请参考官方文档: http://guides.rubygems.org/command-reference/

如何创建自己的ruby gem包的更多相关文章

  1. Ruby Gem命令详解

    转自:http://www.jianshu.com/p/728184da1699 Gem介绍: Gem是一个管理Ruby库和程序的标准包,它通过Ruby Gem(如 http://rubygems.o ...

  2. Ruby Gem命令

    Gem是一个管理Ruby库和程序的标准包,它通过Ruby Gem(如 http://rubygems.org/ )源来查找.安装.升级和卸载软件包,非常的便捷. Ruby 1.9.2版本默认已安装Ru ...

  3. ruby 制作自己的gem包

    在ruby工程目录下新建一个文件:crowdSystem.gemspec.需要在lib目录下存在同一名称的ruby库文件:crowdSystem.rb

  4. npm包与gem包--在线&离线安装

    目录 NPM 在线 离线 GEM 在线 离线 NPM NPM,即为Node的包管理工具,官网为 https://www.npmjs.com/,我们可以在站内搜索所需要的NPM包,了解相关的使用规则 安 ...

  5. ruby gem tips(转)

    淘宝源: https://ruby.taobao.org 升级ruby gem gem update --system 查看gem版本 gem -v 查看gem版本,gems安装目录,remote s ...

  6. (转)-编写第一个ROS(创建工作空间workspace和功能包package)

    原文网址:http://www.cnblogs.com/liuamin/p/5704281.html 刚接触ROS,学着写了第一个程序,怕以后忘记,就将其步骤记录下来.. 首先你必须保证你电脑已安装配 ...

  7. 创建可执行的JAR包

    创建可执行的JAR文件包,需要使用带cvfm参数的jar命令,命令如下:JAR cvfm test.jar manifest.mf testtest.jar和manifest.mf为两个文件,分别对应 ...

  8. SSIS从理论到实战,再到应用(1)----创建自己的第一个包

    原文:SSIS从理论到实战,再到应用(1)----创建自己的第一个包 其实,如果你使用sql2008的导出导入工具的时候,你就已经在使用包了. 目标:使用sql2008 导入导出工具,导入excel数 ...

  9. 编写第一个ROS(创建工作空间workspace和功能包package)

    刚接触ROS,学着写了第一个程序,怕以后忘记,就将其步骤记录下来.. 首先你必须保证你电脑已安装配置好ROS. 1.创建工作空间(workspace) 我们所创建功能包package,应该全部放到一个 ...

随机推荐

  1. 关于支付宝即时到帐异步通知(notify_url)一点总结

    (1)首先做支付的商业网站,需要能够上网(支付成功后,需要进行参数回传验证,如果上不了网,responseText就直接为false)(2)notify_url这个不能进行验证,比如继承父类Page, ...

  2. Platinum UPnP

    http://www.plutinosoft.com/platinum http://blog.csdn.net/lancees/article/details/9178385 Note that P ...

  3. iOS app集成支付宝支付流程及后台php订单签名处理

    iOS app集成支付宝支付流程 1: 开通支付宝商户 由公司去支付宝 https://b.alipay.com/order/serviceIndex.htm 签约支付宝开通支付宝商家: 2:商户支付 ...

  4. Laravel.log日志超级大!怎么办!

    备份项目,发现下载好久没有下载下来.提了网速还是下载了45分钟 解压,解压了25分钟. 想着以为是附件太多... 进入了upload发现也就几百兆. 想看里面内容又打不开...  Laravel 的日 ...

  5. 解决/usr/lib/libstdc++.so.6: version `GLIBCXX_3.4.15' not found错误的解决

    原因是没有GLIBCXX_3..15版本,或是更高的版本. 一.查看并下载 32位系统: [root@localhost ~]# strings /usr/lib/libstdc++.so. | gr ...

  6. C语言位域精解(转)

    有些信息在存储时,并不需要占用一个完整的字节, 而只需占几个或一个二进制位.例如在存放一个开关量时,只有0和1 两种状态,用一位二进位即可.为了节省存储空间,并使处理简便,C语言又提供了一种数据结构, ...

  7. 类的专有方法(__del__)

    # -*- coding: utf-8 -*- #python 27 #xiaodeng #http://www.bubuko.com/infodetail-313791.html #类的专有方法(_ ...

  8. Log4net的配置-按照日期+文件大小混合分割

    ender name="DebugAppender" type="log4net.Appender.RollingFileAppender"><fi ...

  9. Nginx日志分析利器之GoAccess

    1.介绍GoAccess 是一个用来统计 Apache Web 服务器的访问日志的工具,可即时生成统计报表,速度非常快 查看的统计信息有: 统计概况,流量消耗等 访客排名 动态Web请求 静态web请 ...

  10. HDUOJ---大菲波数

    大菲波数 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submis ...