您现在的位置: IT技术文档中心 >> 文档资源 >> 编程语言及开发环境 >> Java >> 文档正文
如何使用 Eclipse 功能部件来定制 Eclipse 行为
作者:未知 文章来源:互联网 点击数: 更新时间:2007-7-19 1:55:40
如何使用 Eclipse 功能部件来定制 Eclipse 行为

级别:高级


Pat McCarthy
资深软件工程师,IBM
2003 年 12 月

如果您想开发插件共享给其他人,那么学习如何有效地使用功能部件是最基本的。本文就如何组织功能部件和优化使用插件开发环境来开发功能部件和插件提出了一些建议,同时介绍了定制 Eclipse 行为的高级技术。即便您只是想学习如何设置 Eclipse,以使您可以自定义任何工作空间的初始化属性值,或者是学习如何使用链接文件来管理您添加到 Eclipse 的组件,本文对您来说也将有所帮助。

构建一个插件是很有趣的:您开始编写代码并创建您想要的工具。把插件拷贝到 Eclipse 或一个基于 Eclipse 的产品中的 \plupgins 目录下,这个插件在 Eclipse 运行期环境中就可以使用了。当再一次使用 Eclipse 的时候,插件将被找到,而且经过平台的启动处理,它在运行期配置中将是可用的。

但是谁知道或者关心您的插件加入了进来?用户可以明白您提供的是什么工具吗?他们可以通过 Eclipse 来禁用、修补或者管理您的组件吗?答案显然是否定的。插件本身仅仅是一个插件,而不是与 Eclipse 平台完全集成的组件。

功能部件包装插件
如果没有功能部件,插件是难以驾驭的,通俗地说,不属于功能部件的插件是未被管理的插件。Eclipse 平台的启动过程包括一个配置的步骤。如果一个新的插件被拷贝到 \plugins 目录,或者以其他方式使 Eclipse 在启动的时候可以找到,配置过程会发现它,但只是通过将新插件的 splash 图标闪烁两次来通知您。Eclipse 之所以会发现新的插件,是因为存贮在 \.metadate\.config\platform 中的当前工作区的配置校验和发生了变化;由于您没有向平台提供一个可以引导用户做出配置修改的功能部件,Eclipse 也只能是通过 splash-flash 来提示这一变化。将您的插件打包为一个(或两个)功能部件,您将获得如下好处:

在 Eclipse 的配置过程中列出您的组件(在 feature.xml 文件中)所要求的先决条件
使您的组件可以作为 Eclipse 配置的活动部分来管理
创建标记信息,让使用那些使用运行期环境的用户可以识别您的组件,并通过一个欢迎页面来告知用户您的功能部件所提供的功能(在关联到您的功能部件的 welcome.xml 文件中)
用 Eclipse 更新管理器可以对您的组件进行修改
不要等到您的插件开发完成后再打包为功能部件。反映在功能部件定义中的设计结果会影响您如何构建您的插件。例如,大多数的 Eclipse 组件都有 UI 功能部件和核心(不是 UI)功能部件。如果您的插件没有按这种方法进行划分,您可能会马上考虑重新设计它们。功能部件也可以用来自动编译处理被引用的插件。

主要功能部件标识一个产品(但是您有控制权)
虽然功能部件很多,但是当您启动 Eclipse 的时候,只有一个功能部件处于控制之下。这个主要功能部件决定了产品的标识和其他运行期行为,包括确定名字和与运行期平台相关联的图示,以及对所有插件默认属性值的重新定义选项。在后面的定义您自己的全局属性中可以看到,这个功能强大的选项使您可以定制您自己的 Eclipse 设置。

功能部件构建插件(如果您允许它们)
插件开发环境(PDE)可以自动完成为完整的运行期环境准备功能部件和插件的大部分工作。参见 Eclipse.org 中文章的讨论 "PDE 生成插件"(在后面的参考资料中有相关链接)。这些基本的步骤在The Java Developer´s Guide to Eclipse(同样参阅后面参考资料中的链接)中也曾作为一个练习涉及到,遵循那个练习您可以构建并标识您已有的插件。可以说如果您有一个功能部件,并且了解 PDE 如何帮助您构建插件和功能部件,您就可以构建一个功能部件,然后让它去同时构建所有相关的插件。构建控制策略(bin.excludes 与 bin.includes)将在后面的使用 PDE 构建功能部件的策略中讨论。这些策略是对 Eclipse.org 文章以及The Java Developer´s Guide to Eclipse一书的补充。

平台配置管理
理解功能部件所需要条件有助于理解它们如何对活动配置中可用的内容进行管理。

启动过程
如果是一个刚解压缩的 Eclipse 平台,那么当您启动 eclipse.exe 的时候将会发生:

安装可能已经完成
如果一个工作区已经存在,那么会有一个 .metadata\.config\platform.cfg 配置文件。

如果您是以常规方式安装 Eclipse,您得运行 eclipse -initialize 命令来生成一个默认的初始化配置文件,放置在 eclipse\.config 目录下。这样当 Eclipse 以新的工作区启动时不再出现 Completing the install 的图示。

找到 Java 运行期环境(JRE)。默认情况下,Eclipse 首先查找 exlipse\jre 子目录。如果没有找到,Eclipse 将查找在系统中注册的 Java 运行期环境。
注意:-vm dir-location 参数可以用到指定其他的 JRE。
配置被作为新的工作区的一部分创建出来。新的工作区通常没有任何的配置,所以您会在真正的 splash 图标之前看到一个图标,通知您安装设置完成。
处理那些注册到 Eclipse 的功能部件和插件,并创建在后面将会用于检测变化的校验和。这些功能部件和插件或者位于当前的 eclipse\features 目录和 eclipse\plugins 目录下,或者位于由链接文件指定的 eclipse\... 目录结构中。
一旦 Eclipse 启动,活动配置定义将包含在 .metadata\.config\platform.cfg 文件中。

链接文件如何扩展一个 Eclipse 安装设置
如果您已经使用了一段时间的 Eclipse 或者在您的配置中添加了哪怕只是一个新的插件,您肯定知道 Eclipse 是到 eclipse\features 目录和 eclipse\plugins 目录下去查找功能部件和插件的。不过您是否知道,Eclipse 也会到文件系统的其他位置去查找功能部件和插件?如果在 eclipse\links 目录下存在格式正确的链接文件,那么这些文件会被处理,相关联的功能部件和插件(包括没有相关功能部件的插件)在运行期配置中都会是可用的。

一个链接文件只是一个命名为 id.link 的任意文件,在这里 id 通常是正在被引用的根功能部件的 id。您可以在链接文件目标中定义不只一个功能部件,并且名字命名为 foo.link 也是可以接受的。给出一个包含如下内容的链接文件:

path=E:/Eclipse-2.1.1/installedFeatures/Examples

Eclipse 将会到指定的目录下去查找 eclipse\features 目录和 eclipse\plugins 目录,看是否有合法的功能部件和(或)插件。也就是说,目标目录必须包含一个 \eclipse 目录。如果找到,附加的功能部件和插件在运行期配置是将是可用的,如果链接文件是在工作区创建之后添加的,附加的功能部件和插件会作为新的配置变更来处理。

使用链接文件来定制您自己的 Eclipse 安装设置的策略将在本文稍后的使用链接文件管理 Eclipse 安装设置中进行讨论。

配置更新?D?D添加一个功能部件
如果一个新的功能部件及所用到的插件已经添加到已有的 \features 目录和 \plugins 目录下,或者通过一个链接文件注册到 Eclipse,校验和的变化将触发配置处理过程。这个处理在一个简单的 splash-flash 之后进行。新的功能部件作为一个配置变更来处理,并且显示出一个配置变更的对话框。

例如,如果您打开一个标准的 Eclipse 解压缩环境的工作区,而后找到了 Eclipse Examples,您把它解压缩到与 Eclipse 同样的目录树中或者添加了一个链接文件来指明这个例子解压缩到了何处,将会出现一个如图1所示的对话框。
所以,如果您看到类似于这样的一个对话框,那是因为在您运行一个安装配置程序的时,您自己或者其他人修改了 Eclipse 的配置,而平台发现了新的或者更新过的可用功能部件。如果条目可以被选中,您可以将这个变化添加到您当前的配置中。如果条目被禁用,说明存在配置上的问题,这个功能部件不能被添加进来。按下 Error Details 按钮可以查看有关配置问题的信息。

配置管理注解:

存在未决变更并不意味着您不得不马上接受它们,在相当一段时间内您完全可以不去理会它们,只需要取消对条目的选择,并点击 Finish即可。要在以后再添加它们,您可以选择 Help > Software Updates > Pending Changes... 来再次打开那个对话框。
已经被接受的变更在以后还可以禁用。打开 Install/Update 透视图,在 Install Configuration 视图中选中功能部件,然后在 Preview 视图中选择 Disable 。禁用的功能部件还可以通过类似的步骤启用。在 Install Configuration 视图中点击 Show Disabled Features 图标可以显示被禁用的功能部件。
功能部件在运行期标识组件
Eclipse 允许标识活动产品,也可以选择标识运行期配置中的每一个功能部件。功能部件不是必须要标识出来,您可以不标识您所有的功能部件,但是您应该至少标识一个。

标识定义?D?D插件的工作
添加标识的关键问题是要明白把标识的定义在哪里。您定义标识的是功能部件,但是标识的内容是来自于插件。或者插件与功能部件的 id 相同(默认的情形),或者插件在功能部件的定义中被明确标识(这是 Eclipse 2.1.1 的新增功能)。在 Eclipse 2.1 中,一个功能部件定义可以通过在 feature.xml 文件中指定属性 plugin=… 来定义其他插件。

插件包含了用于定义和提供标识内容的文件。

标识内容概要介绍
about.ini 控制文件定义了产品级和功能部件级的标识。产品标识必须正确包含以下两方面内容:

功能部件必须被定义为一个可能的主要功能部件,即在 feature.xml 定义文件中要包含 primary="true"。
功能部件必须被标识为活动的主要功能部件,在产品中通常是在 \eclipse 目录下的 install.ini 文件中的条目来设置。主要功能部件也可以在运行期通过使用 -feature featureId 启动参数来定义。
理解功能部件标识的最简单的办法是去查看在 about.ini 控制文件中定义了哪些元素,以及它们在一个被标识的产品或功能部件中如何起作用。
以下几条仅用于产品标识:

windowImage
appName
aboutImage
其余条目在产品及功能部件标识过程中使用。

以百分号(%)开头的值在 about.properties 文件中解析。当一个功能部件是主要功能部件时,用 abouText 关键字定义的文本会在 About product 对话框中显示。当用户点击 Feature Details 按钮时,随后弹出的 About Features 对话框中也会显示这些本文内容。

功能部件被加入到运行期配置时,会打开 welcomePage 条目指定的欢迎页面,其后还可以通过选择 Eclipse 菜单选项 Help > Welcome... 打开的 Welcome 选择对话框打开这个欢迎页面。

构建一个可行的有标识的功能部件的最快速方法是克隆一个在 Eclipse 本身中可以找到的一个现有的功能部件。具有 org.eclipse.platform id 的功能部件和插件会提供功能部件标识和插件标识。在The Java Developer´s Guide to Eclipse一书第34章练习7中有一个步骤详尽的指导说明。

在 Eclipse.org 的更新管理器子工程的开发资源中,您可以找到另外一些关于标识的详细说明(参见参考资料中的链接)。

使用 PDE 构建功能部件的策略
在The Java Developer´s Guide to Eclipse一书中关于功能部件开发的章节和 Eclipse.org 的文章 "PDE 生成插件"中都对构建功能部件的过程进行了介绍,但是也还有一些其他的途径。当您理解了如何使用 PDE 来构建功能部件和相关联的插件之后,您可以让这些步骤自动完成。

由 PDE 实现的 Ant 目标
让我们从对 PDE 所提供功能概要介绍开始讲起。PDE 将为一个 plugin.xml 或 feature.xml 文件生成 build.xml 文件。Build.xml是一个 Ant 脚本,可以完成运行期平台的功能部件和插件所需要的不同任务。PDE 构建过程允许您生成下列构建目标中的一个或多个。

重要的功能部件构建目标:

build.jars 为每一个引用到的插件调用 build.xml 文件中的 build.jars 任务。
build.update.jar 为每一个引用到的插件调用 build.xml 文件中的 build.update.jars 任务。同时会为功能部件创建一个 Update JAR。这是 Ant 脚本的默认目标。
build.sources 为每一个引用到的插件调用 build.xml 文件中的 build.source 任务。
zip.distribution 创建一个包含功能部件和引用到的插件所需要的所有文件的压缩文件。
refresh 使 Eclipse 刷新功能部件工程及任何引用到的插件的工程。
重要的插件构建目标:

build.jars 为插件定义的每一个运行期 JAR 调用 build.xml 文件中的许多目标。被调用的目标的名字与运行期 JAR 文件的名字相同。这些目标编译 Java 代码并创建 JAR 文件,包含任何在源文件目录下的资源。
build.update.jar 将所有运行期插件目录下所有需要的文件压缩打包为一个名字为 plugin.id_version.jar 的文件,在这里 plugin.id 和 version 来自于 plugin.xml 文件。这是 Ant 脚本的默认目标。
build.sources 基于给定的运行期 JAR 文件所定义的源文件目录,创建 Java 源文件的压缩包。
zip.plugin 创建一个包含有插件所需要的所有内容的压缩包。
refresh 使 Eclipse 刷新插件工程。
注意:在功能部件和插件的Ant 处理过程中,更新 JAR 或生成压缩包的处理过程中打包的文件,是运行期环境所需要的那些文件。这些内容在功能部件或插件的 build.properties 文件和在 plugin.xml 中定义的每一个插件的运行期 JAR 文件中,通过 bin.includes 或者 bin.excludes 条目来描述。

为了构建一个插件,您可能会指定 clean,build.sources,build.jars,zip.plugin,refresh。为了构建一个功能部件,您可能会指定clean,build.sources,build.jars,zip.distribution,refresh。您或许会想要在开始时使用 clean 来强制重新生成所有结果,经常会有这种情况。尽管 Ant 处理过程将基于输入的变化重新执行所需要的步骤,但是有一些变化不会触发所有需要的处理过程。测试结果表明如果您改变了一个 Java 源文件,相应的源文件压缩包将会更新,但是类不会被重新编译,运行期 JAR 也不会被更新。所以安全起见,建议您先将输出结果清空,以保证您在重新构建后所使用的是对应于当前源文件的运行期版本。

讨论方案
为了进行讨论,我们先描述一下只有一个功能部件和插件时在运行期配置中需要的内容。

组件结构示例

组件类型
文件

功能部件
feature.xml

feature_image.jpg

/license/license.html

/license/license.pdf

/plan/project-plan.doc

插件
plugin.xml

/images/action.gif

/images/editor.gif

/src/co/pkg/id/action.java

/src/co/pkg/id/editor.java

/design-docs/plug-in.doc

/design-docs/editor.doc


正如您所看到的文件名,虽然这些文件大部分属于运行期环境,还是有一些文件不是您想要与其他人共享的(例如,您的设计文档)。

包含策略?D?D指出所需要的部分
至少到刚开始时,最简单的方法是,在构建过程中将您要打包的部分作为在运行期配置中功能部件或插件的一部分而列出来。相应的 build.properties 文件分别如下所示:

build.properties 内容

组件
build.properties 文件内容

功能部件
bin.includes = feature.xml,\
license/

插件
source.runtime.jar = src/
bin.includes = plugin.xml,\
images/


排斥策略?D?D指定不需要的或私有的部分
另一种方法是把您不想打包的部分在构建过程中作为功能部件或插件的一部分列出来。这不仅要包括您不想共享的文件,还要包括构建过程中创建的文件和目录(有一些是临时的)。这种方法用到的 build.properties 文件如下:

build.properties 内容

组件
build.properties 文件内容

功能部件
bin.excludes = temp.folder/,\
com.ibm.master.lab.core_1.0.0.bin.dist.zip,\
.classpath,\
.project,\
build.xml,\
build.properties

插件
bin.excludes = temp.folder/,\
bin/,\
.classpath,\
.project,\
build.xml,\
build.properties,\
makesrczip.xml,\
src/


如果给定功能部件或插件的 id 值为 com.your.feature.id 或者 com.your.plugin.id,那么您在使用排斥策略的时候还需要在文件中包括以下条目:

com.your.feature.id_1.0.0.bin.dist.zip,\
com.your.feature.id_1.0.0.jar,\
com.your.plugin.id_1.0.0.jar,\

[1] [2] 下一页

  • 上一篇文档:
  • 下一篇文档:
  • 网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)
    | 设为首页 | 加入收藏 | 联系站长 | 版权申明 | 雁过留声 | 会员中心 |