近日,流行的 Scala Web 框架 Lift(单击以查看InfoQ 上关于Lift 的更多报道)想通过一个JRuby API 吸引Ruby 程序员。Lift 创建者 David Pollak 写到:“除了某些特殊情况,JRuby 中可以完美应用 Lift”。
但既然有了 Rails 和其他 Ruby 框架可以开发 Web 应用,Ruby 开发者为何还会使用 Lift 呢?David 在声明中写到:
Lift 无疑是目前最为优秀的 Web 框架。相对于其他任何 Web 框架来说,它对 Comet 和 Ajax 都提供了更好的语义支持。默认情况下,它比其他大多数框架都更为安全。基于 Lift 的应用的可伸缩性也更棒。Lift 应用要比其他大多数 Web 应用都更为简洁。换句话说,如果你是个 Ruby 开发者,正在寻找更加安全、可伸缩性更好的 Web 框架以构建交互性更好的应用,那么 Lift 就是你的不二之选。
你可以通过 Lift’s Seven Things 站点验证上面这些声明,该站点提供了一些示例,演示了“其他 Web 框架很难或是根本没法实现的 7 件事”。
我们向 David 问到:将 Lift 带给 Ruby 程序员的动机是什么。
我热爱 Scala,它是我最钟情的编程语言。在与一些开发组织交流并看到 Scala 的使用率之后,我认识到 Scala 在未来几年内的使用率不可能达到 Ruby,甚至是 Python 的水平。另一方面,Lift 已经演变为一个成熟的 Web 框架,比其他任何 Web 框架(看看 Seven Things 吧)都更为安全、更易于构建交互式应用。因此,我决定在 Lift 中支持其他语言。 我相信这么做是正确的,并且招聘了几名资深的 Ruby 开发者帮助我在 Lift 中开发 Ruby API,他们看起来像是 Ruby API,而非生硬地添加到 Lift 之上的附属物。我们打算采用 Ruby 的方式编写 Lift-Ruby 代码。感兴趣的读者可以到 http://liftjr.org 了解更多信息。
我真诚希望 Lift 之上的 Ruby API 能够以一种比 Scala API 更好的方式将 Lift 暴露出来,未来某一天,Ruby 方式终究会对 Lift 的 Scala API 产生积极的影响。
但作为静态语言 Scala 的拥趸,我的主要目标是少说、多听,看看我们到底能将 Ruby API 开发到什么程度。
InfoQ:从 JRuby 中访问 Scala 或是从 Scala 中访问 JRuby 会遇到什么问题呢?
JRuby API 是整洁、平滑且易于使用的。除了标准的 unityped 与完整的类型之间的差别外并没有什么实际的问题,请查看 Philip Wadler 的介绍。 如果从 JRuby 中访问 Scala,那么 Scala 的 singletons(object 关键字)会产生一些问题,我们已经增强了 JRuby,将其当作是 Ruby 的 Class 对象。Scala 还有一些符号方法名(如!、%、& 等等),我们需要将其在 JRuby 中公开出来,现在正在解决这个问题。
InfoQ:Scala 的一个非常灵巧,又被经常使用的一个特性就是模式匹配,而这在 Ruby 中却没有对应之物。你提到了 Ruby 中用于模式匹配的 DSL,能否向我们介绍一下呢?
这或许是整个项目中最为困难的一部分了。我们针对 Actor 做了一个设计(尚未实现),看起来还不错:
复制代码
class MyActor < LiftActor def string(str) # same as case str: String => end def some_message(p1, p2) # same as case SomeMessage(p1, p2) => end end我们还具体分析了每一种模式匹配的情况。重申一次,这个想法是以 Ruby 的方式编写 API,但却反映出 Lift 的语义而不是将 Scala 语法硬塞到 Ruby 语法中。 Lift Google Group 上的其他 Ruby 开发者的建议也是非常不错的。
Lift JRuby 集成有自己的站点( liftjr.org )。不知读者怎么看?Ruby 和 Scala 社区会从这种跨界中受益么?
查看英文原文: Lift-JRuby Integration Bridges the Gap Between Ruby and Scala
评论