Eclipse等IDE靠着从Smalltalk IDEs里吸收养分已经赢得了很多用户——增量编译、本地版本管理就是其中的两个。不过Smalltalk IDEs(或Emacs等编辑器)仍然占据优势的一个领域,就是IDE本身的自动化:在IDE里将重复性的工作变成脚本。Smalltalk用户可以直接用Smalltalk去访问IDE的对象,Emacs用户用LISP可以完成同样的工作——不但可以交互式地完成,还可以在运行时进行。
\u0026#xD;\n
Eclipse Monkey为Eclipse提供了一个方案——Eclipse Monkey的名字来自著名的Firefox插件GreaseMonkey。它的第一版用Javascript(基于Java的Rhino)作为脚本语言,但Christopher Williams最近宣布也可以用Ruby(采用JRuby)来编写脚本了:
\u0026#xD;\n
如果你不熟悉EclipseMonkey,它是一组Eclipse插件,可以和用户交互,并用非Java的其他语言(最初仅支持Javascript)来给IDE写脚本。更详细的信息你可以查阅http://www.eclipse.org/dash/monkey-help.php?key=writing。 EclipseMonkey的Ruby扩展开启了用Ruby代码编写IDE脚本的能力。
最初的版本暴露了一个Editor DOM,让你可以用脚本去操纵编辑器。我们在Wiki上已经准备了一些帮助,里面描述了很多细节以及Editor DOM的API信息。我们也提供了一些示例脚本,演示如何使用这个功能。
\u0026#xD;\n
Eclipse Monkey的设计实践了“简单”原则——这么做是有原因的:这个项目的发起人和设计者之一是 Ward Cunningham,他与其他人一起在1990年代发明了Wiki。脚本是项目中的一些文本文件;任何元数据都保存在文件自身里面。元数据包括依赖性,或者运行脚本的一个快捷方式的声明。你可以把一个脚本与Eclipse中的任意事件挂钩,比如文件变更、文件保存或者程序启动。
\u0026#xD;\n
下面是一段用Ruby写的Eclipse Monkey脚本,用来把编辑器里的String转成Symbol:
\u0026#xD;\n
=begin\u0026#xD;\n
\u0026#xD;\nMenu: Ruby \u0026gt; String to Symbol\u0026#xD;\n
\u0026#xD;\nKudos: Christopher Williams\u0026#xD;\n
\u0026#xD;\nKey: M1+Shift+;\u0026#xD;\n
\u0026#xD;\nLicense: EPL 1.0\u0026#xD;\n
\u0026#xD;\nDOM: http://download.eclipse.org/technology/dash/update/org.eclipse.eclipsemonkey.lang.ruby\u0026#xD;\n
\u0026#xD;\n=end\u0026#xD;\n
\u0026#xD;\n# If the current token is a string containing alnums, change it to\u0026#xD;\n
\u0026#xD;\n# a symbol\u0026#xD;\n
\u0026#xD;\neditor = $editors.get_active_editor\u0026#xD;\n
\u0026#xD;\nselection = editor.selection_range\u0026#xD;\n
\u0026#xD;\nselected_src = editor.source[selection]\u0026#xD;\n
\u0026#xD;\n# if entire selection is a string with no dynamic content, then\u0026#xD;\n
\u0026#xD;\n# convert the string to a symbol\u0026#xD;\n
\u0026#xD;\nmatch = selected_src.match(/(['\"])([_a-zA-Z][_\\w]*)\\1/)\u0026#xD;\n
\u0026#xD;\nreturn if match.nil? || match.size != 3\u0026#xD;\n
\u0026#xD;\nsymbol = \":\" + match[2]\u0026#xD;\n
\u0026#xD;\neditor.apply_edit(selection.first, selection.size - 1, symbol) \u0026#xD;\n
Eclipse Monkey中的另一个概念是DOM,别跟HTML或者XML DOM搞混了,它代表的是Domain Object Model。它是一个为特定领域的某些功能提供简化接口的一个对象。
\u0026#xD;\n
以上面的代码为例,$editors
变量指向一个处理所有与Editors相关之事的DOM。为Eclipse这类IDE编写脚本,DOM是必要的简化之举。通过直接访问Eclipse对象、系统及API来完成相同的事情也是可以的,不过写出来的脚本很可能会变得更加复杂。这是由于Eclipse的设计非常灵活,它具备的若干概念也造就了它的扩展能力——但也意味着像$editors.get_active_editor
这样简单的一句表达式要变成2-3行代码。
\u0026#xD;\n
这些DOM都是普通的Eclipse插件,贡献到org.eclipse.eclipsemonkey.dom
扩展点,因此在Eclipse的插件开发环境(PDE)中编写一个简化的功能接口是很容易的。Eclipse Monkey的元数据也有助于DOM的配置管理:脚本的元数据段可以指定它所需DOM的update site,当脚本运行的时候系统就会自动去获取需要的DOM。
\u0026#xD;\n
由于Eclipse Monkey脚本在Eclipse的JVM里运行,因此可以在脚本里使用所有的Java API和所有的JRuby标准库。现在已经存在很多Eclipse Monkey DOM,让开发者得以访问Eclipse和Eclipse插件元系统提供的丰富代码和功能。
\u0026#xD;\n
例如用JMX DOM就可以通过JMX来控制JVM。通过简单的脚本就能够调用所有的JMX操作,查询所有的JMX属性。在实用中可以用它来从Eclipse启动一个程序,设置程序的属性(比如日志级别),调用程序的操作(比如执行垃圾收集)——只需简单的一步。别的DOM还可访问比如CVS/SVN插件、工作区、JDT等等。
\u0026#xD;\n
更多信息可参阅Aptana的Eclipse Monkey网站,或者Eclipse Monkey网站的官方页面。
\u0026#xD;\n
查看英文原文:IDE scripting with Ruby and Eclipse Monkey