JRuby 编译器完工

  • Werner Schuster
  • 郭晓刚

2007 年 9 月 29 日

话题:JavaRuby编程语言DevOps语言 & 开发架构文化 & 方法

Charles Nutter 已经花了不少时间去开发 JRuby 的Ruby 到 Java 字节码的编译器。现在这项工作已经完成

我刚刚做完了 BEGIN 和 END 块的编译,这样整个编译器就完成了。我还成功地编译了整个标准库,而且我完全靠编译过的脚本成功运行了 IRB 和 RubyGems(即,我删除了全部的.rb 文件)。

这样JRuby 1.1 计划中提到的部分项目就已经完成了。预计在 11 月初举行的RubyConf 2007之前发布的 JRuby 1.1 将会包括这个编译器。

更详细的信息可以在宣布 JRuby 编译器完成的公告中找到

破天荒第一次,我们有了一个完整的、全功能的 Ruby 1.8 编译器。之前已经有其他编译器宣布能够处理所有的 Ruby 语法,甚至能够编译整个标准库。但都还达不到我眼中的真正“完整”:即使扔掉 stdlib 里面所有的.rb 文件,仍然能继续运行比较重大的程序如 IRB 或者 RubyGems。我想这一点成就应该值得我自豪。JRuby 有了第一个完整、全功能、支持 Ruby 1.8 语义的编译器。这是很酷的一件事。

另一种类型的编译器也已经在计划当中。它将会进一步促进 Java 与 Ruby 的集成。

编译器第 2 号大致上是将一个给定文件中的 Ruby 类(或者多个 Ruby 类,如果你想的话),转换成普通的 Java 类型。这个类型将会与其他 Java 类的表现一样:

  • 你可以用 new MyClass(arg1, arg2) 这样的普通 Java 代码来实例化它。
  • 你可以用普通的 Java 方法调用来调用它的全部方法。
  • 你可以用 Java 类来扩展它。

还需要一点加强才能实现在 Java 中使用这些转换出来的类。比如需要用特定的签名来定义方法。因为 Ruby 的方法签名中没有显式的类型信息,所以要使用一些特别的技巧:

我已经想过用独立于实现的方案来指定 Ruby 方法的签名。我所假定的需求是,能运行在 JRuby 里面的代码也要能够不经修改就在其它 Ruby 实现中正常运行;只不过在 JRuby 中,代码还获得了额外的静态类型签名,让它能够被 Java 代码调用。我现在打算的语法是像下面的样子:

class MyClass

...

{String => [Integer, Array]}

def mymethod(num, ary); end

end
如果你觉得陌生,其实它只不过是基本的字面值哈希语法。返回类型 String 跟方法的两个参数的类型(Integer 和 Array)关联起来。在任何普通的 Ruby 实现中,这一行都会执行并构造出一个哈希值,执行会继续下去,这个哈希值可能很快就会被垃圾回收。不过如果是编译器第 2 号,它就会用这样的行来创建出类似下面的方法签名:

    public String mymethod(int num, List ary) {

...

}

查看英文原文:JRuby compiler finished

JavaRuby编程语言DevOps语言 & 开发架构文化 & 方法