【IT168技术资讯】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) {
...
}
原文:http://www.infoq.com/cn/news/2007/09/jruby-compiler-finished