QCon 演讲火热征集中,快来分享技术实践与洞见! 了解详情
写点什么

用 Ruby 和 Eclipse Monkey 编写 IDE 脚本

  • 2007-11-01
  • 本文字数:1875 字

    阅读完需:约 6 分钟

Eclipse 等 IDE 靠着从Smalltalk IDEs 里吸收养分已经赢得了很多用户——增量编译、本地版本管理就是其中的两个。不过 Smalltalk IDEs(或Emacs等编辑器)仍然占据优势的一个领域,就是 IDE 本身的自动化:在 IDE 里将重复性的工作变成脚本。Smalltalk 用户可以直接用 Smalltalk 去访问 IDE 的对象,Emacs 用户用 LISP 可以完成同样的工作——不但可以交互式地完成,还可以在运行时进行

Eclipse Monkey 为 Eclipse 提供了一个方案——Eclipse Monkey 的名字来自著名的 Firefox 插件 GreaseMonkey。它的第一版用 JavaScript(基于 Java 的 Rhino)作为脚本语言,但 Christopher Williams 最近宣布也可以用Ruby(采用 JRuby)来编写脚本了

如果你不熟悉 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 信息。我们也提供了一些示例脚本,演示如何使用这个功能。

Eclipse Monkey 的设计实践了“简单”原则——这么做是有原因的:这个项目的发起人和设计者之一是 Ward Cunningham,他与其他人一起在 1990 年代发明了Wiki 。脚本是项目中的一些文本文件;任何元数据都保存在文件自身里面。元数据包括依赖性,或者运行脚本的一个快捷方式的声明。你可以把一个脚本与Eclipse 中的任意事件挂钩,比如文件变更、文件保存或者程序启动。

下面是一段用Ruby 写的Eclipse Monkey 脚本,用来把编辑器里的String 转成Symbol

复制代码
=begin
<br></br>
Menu: Ruby > String to Symbol
<br></br>
Kudos: Christopher Williams
<br></br>
Key: M1+Shift+;
<br></br>
License: EPL 1.0
<br></br>
DOM: http://download.eclipse.org/technology/dash/update/org.eclipse.eclipsemonkey.lang.ruby
<br></br>
=end
<br></br>
# If the current token is a string containing alnums, change it to
<br></br>
# a symbol
<br></br>
editor = $editors.get_active_editor
<br></br>
selection = editor.selection_range
<br></br>
selected_src = editor.source[selection]
<br></br>
# if entire selection is a string with no dynamic content, then
<br></br>
# convert the string to a symbol
<br></br>
match = selected_src.match(/(['"])([_a-zA-Z][_\w]*)\1/)
<br></br>
return if match.nil? || match.size != 3
<br></br>
symbol = ":" + match[2]
<br></br>
editor.apply_edit(selection.first, selection.size - 1, symbol)

Eclipse Monkey 中的另一个概念是DOM,别跟 HTML 或者 XML DOM 搞混了,它代表的是 **Domain Object Model**。它是一个为特定领域的某些功能提供简化接口的一个对象。

以上面的代码为例,$editors变量指向一个处理所有与 Editors 相关之事的 DOM。为 Eclipse 这类 IDE 编写脚本,DOM 是必要的简化之举。通过直接访问 Eclipse 对象、系统及 API 来完成相同的事情也是可以的,不过写出来的脚本很可能会变得更加复杂。这是由于 Eclipse 的设计非常灵活,它具备的若干概念也造就了它的扩展能力——但也意味着像$editors.get_active_editor这样简单的一句表达式要变成 2-3 行代码。

这些 DOM 都是普通的Eclipse 插件,贡献到org.eclipse.eclipsemonkey.dom扩展点,因此在 Eclipse 的插件开发环境(PDE)中编写一个简化的功能接口是很容易的。Eclipse Monkey 的元数据也有助于 DOM 的配置管理:脚本的元数据段可以指定它所需 DOM 的 update site,当脚本运行的时候系统就会自动去获取需要的 DOM。

由于 Eclipse Monkey 脚本在 Eclipse 的 JVM 里运行,因此可以在脚本里使用所有的 Java API 和所有的 JRuby 标准库。现在已经存在很多 Eclipse Monkey DOM,让开发者得以访问 Eclipse 和 Eclipse 插件元系统提供的丰富代码和功能。

例如用JMX DOM 就可以通过JMX 来控制JVM 。通过简单的脚本就能够调用所有的JMX 操作,查询所有的JMX 属性。在实用中可以用它来从Eclipse 启动一个程序,设置程序的属性(比如日志级别),调用程序的操作(比如执行垃圾收集)——只需简单的一步。别的DOM 还可访问比如CVS/SVN 插件、工作区、JDT 等等。

更多信息可参阅 Aptana 的 Eclipse Monkey 网站,或者 Eclipse Monkey 网站的官方页面

查看英文原文: IDE scripting with Ruby and Eclipse Monkey

2007-11-01 06:011507
用户头像

发布了 225 篇内容, 共 65.3 次阅读, 收获喜欢 50 次。

关注

评论

发布
暂无评论
发现更多内容

自己手写一个redux

helloworld1024fd

JavaScript

从实现一个React到深度理解React框架核心原理

夏天的味道123

React

Vue组件是怎样挂载的

yyds2026

Vue

云小课|MRS基础原理之Oozie任务调度

华为云开发者联盟

大数据 华为云 企业号十月 PK 榜

人人能读懂redux原理剖析

夏天的味道123

React

Vue虚拟dom是如何被创建的

yyds2026

Vue

线上数据问题排查案例分享-因为 HMS 和底层 orc 文件中某字段的数据精度不一致造成的数据丢失问题

明哥的IT随笔

hadoop hive DataX

前端常考手写面试题汇总

helloworld1024fd

JavaScript

python计算机二级 常用函数操作

Python-派大星

10月月更

一文读透react精髓

xiaofeng

React

redux原理是什么

xiaofeng

React

Docker进阶 dockerfile指令构建docker镜像

Python-派大星

10月月更

引擎上新|卡片焕新升级,信息高效呈现

Jianmu

DevOps 持续集成 CI/CD

彻底搞懂React-hook链表构建原理

夏天的味道123

React

京东云开发者|ElasticSearch降本增效常见的方法

京东科技开发者

elasticsearch ES 降本增效 数据压缩 存储计算分离

Vue模板是怎样编译的

yyds2026

Vue

webpack模块化的原理

Geek_02d948

webpack

【文本检测与识别白皮书-3.2】第二节:场景文本识别方法

合合技术团队

人工智能 深度学习 文字识别 OCR 文本识别

云计算基础:云计算运用越来越广泛,我们应该如何去学习云计算

Python-派大星

10月月更

对Swift中some和any关键字的理解

珲少

【沙丘大会】九科信息研发中心自动化负责人郑文茂受邀分享央企数字员工实践案例

九科Ninetech

长安链源码分析同步服务器1

Workflow,要不要了解一下

华为云开发者联盟

人工智能 华为云 企业号十月 PK 榜

webpack实战,手写loader和plugin

Geek_02d948

webpack

小样本学习在文心ERNIE3.0多分类任务应用--提示学习

汀丶人工智能

nlp 文本分类

SAP | 子例程

暮春零贰

SAP 10月月更 子例程

那些你不知道的炫酷导航交互效果

南城FE

CSS 前端 交互设计 导航 交互

Java:既然有了synchronized,为什么还要提供Lock

华为云开发者联盟

Java 开发 华为云 企业号十月 PK 榜

【1024程序员节专访】聚焦行业前沿,共话IT发展趋势

博睿数据

程序员 可观测性 智能运维 博睿数据 IT行业

5 why 分析法,一种用于归纳抽象出解决方案的好方法

程序员泥瓦匠

Webpack配置实战

Geek_02d948

webpack

用Ruby和Eclipse Monkey编写IDE脚本_Ruby_Werner Schuster_InfoQ精选文章