eclipse 插件模型

Eclipse是一个可扩展的平台,它提供了一些核心的服务,使一系列的工具集协作完成软件开发的任务。工具设计师通过将它们的工具包装成可拔插的组件来扩展eclipse的功能。这些可拔插的组件被称为“eclipse插件”,它们遵循eclipse的插件规范。eclipse的基本扩展机制是:通过核心插件来提供的平台,新的插件可以增加处理部件到现有的插件。

尽管ecliipse平台以构建IDE著称,但它是由许多不同开发者开发的一系列的插件共同组成的。

 

一、eclipse的插件模型

eclipse中,插件是在eclipse工作平台上的一个能提供某种服务的组件。一个组件就是一个对象,该对象能够在运行前被配置到一个系统中。eclipse的运行时系统就提供了这样的功能,支持组件的激活,并使一些插件集协作来提供一个无缝的开发环境。在一个eclipse实例中,一个插件被一个或一些插件运行时类或插件类所管理。也就是说,插件类提供了配置和管理插件实例的功能。一个插件类必须扩展自org.eclipse.core.runtime.Plugin,该类是一个提供了基本插件管理功能的抽象类。

eclipse安装目录下含plugins文件夹,该处就是插件所在位置。一个插件被一个plugin.xml文件所描述,它告诉eclipse运行时如何激活该插件。

最基本的plugin.xml文件如下:

<?xml version="1.0" encoding="UTF-8"?>

<plugin

  name="JUnit Testing Framework"

  id="org.junit"

  version="3.7"

  provider-name="Eclipse.org">

  <runtime>

    <library name="junit.jar">

      <export name="*"/>

    </library>

  </runtime>

</plugin>

每个插件有一个全局唯一的标识符id,用于标识该插件。

 

二、插件的配置和激活

插件的安装很简单,只需将插件文件夹拷贝到plugins文件夹内,这样该插件就可以在适当的时候被eclipse运行时系统激活。激活意味着加载它的运行时类并将其实例化。插件类就是在插件激活startup或反激活shutdown时完成一些特殊工作的类。

eclipse包含一个插件管理核心,称为”eclipse平台“或”eclipse运行时“。每次启动时会自动加载一些核心插件。其它非核心插件只有在有需求时,才被激活。

eclipse模型中,一个插件可能和其它插件有下列两种关系:

1.依赖require  :该插件的运行需要其它插件的支持。

2.扩展extension:该插件扩展了原插件的功能。

如:

<?xml version="1.0" encoding="UTF-8"?>

<plugin

   id="com.bolour.sample.eclipse.demo"

   name="Extension Processing Demo"

   version="1.0.0">

   <runtime>

      <library name="demo.jar"/>

   </runtime>

   <requires>

      <import plugin="org.eclipse.ui"/>

   </requires>

</plugin>

三、扩展Extension

当一个插件提供给用户使用时,一些UI元素将被加到基本的eclipse工作台。

增加一些处理部件到一个插件的过程称为扩展extension,这个过程并不限于UI元素。

一个扩展由一个扩展器插件extender plug-in定义,该扩展会引起主插件host plug-in在行为上的改变。典型情况是,包括向主插件中增加处理部件(例如,向eclipse工作台上增加新的菜单),自定义新增部件的行为(例如,自定义菜单项的处理句柄)。

简单情况下,扩展的一个单独行为将会增加一个单独的回调对象到该环境中,callback对象是主插件和扩展插件的交流桥梁。callback对象不同于主插件和扩展插件(它们都自动被eclipse平台实例化并管理),它是一个plain-old-java-object,它通过开发者提供的特殊代码来实例化和管理。

扩展的一个单独行为也能够增加多个callback对象到环境中。例如,eclipse允许通过一个单一的扩展增加多个菜单。

然而,从本质上来说,扩展模型并非必须要求扩展器插件提供一个自定义的callback对象。比如说,以下的情况是可能的:主插件所需的行为变化能够完全由某些类提供,这些类在编译时就可以被主插件识别,这样一来,该扩展声明仅仅会引起实例化这些内建的对象。

类似地,扩展模型也不要求主插件直接地将其扩展的各个部分暴露出来。例如,一个扩展仅仅要求在主插件发生某些特定事件时通知扩展器插件,在主插件的UI上无需任何的改变。

 

一个插件可能容许自己被各种不同的extension所扩展。例如,工作台UI容许它的菜单和编辑器被扩展。不论哪种扩展,extension都必须遵循一系列特殊的配置规范和行为需求。因此,一个可扩展的插件提供了许多不同类型的”空位slot“来让extension插入。这些空位的类型被称为“扩展点extension-point”。

 

 

可见,存在两种类型的插件角色:hostextender。通用角色callback对象,以及与每个扩展点对应的特定的callback对象。

Host插件提供扩展点,并充当协调和管理一些extension扩展的角色。在主插件的plugin.xml文件中,扩展点由extension-point XML元素来定义,

<?xml version="1.0" encoding="UTF-8"?>

<plugin

id="org.eclipse.ui"

    name="Eclipse UI"

    version="2.1.0"

    provider-name="Eclipse.org"

    class="org.eclipse.ui.internal.UIPlugin">

 

<extension-point id="actionSets" name="Action Sets"

      schema="schema/actionSets.exsd"/>

    <!-- Other specifications omitted. -->

</plugin>

 

Extender角色的插件定义了extension,一般是使自己的某些方面对主插件来说可用,除此之外,使主插件增加一些processing elements到它的环境。一个extension是通过扩展器插件的plug-in.xml文件中的“extension XML元素”来说明的。

<plugin

        id="org.eclipse.help.ui"

        name="Help System UI"

        version="2.1.0"

        provider-name="Eclipse.org"

        class="org.eclipse.help.ui.internal.WorkbenchHelpPlugin">

    <!-- ... -->

    <!-- Action Sets -->

    <extension

        point="org.eclipse.ui.actionSets"> //使用完全限定名来指定待扩展的扩展点

        <actionSet

                label="Help"

                visible="true"

                id="org.eclipse.help.internal.ui.HelpActionSet">

        <action

                label="&Help Contents"

                icon="icons/view.gif"

                helpContextId="org.eclipse.help.ui.helpContentsMenu"

                tooltip="Open Help Contents"

                class="org.eclipse.help.ui.internal.HelpContentsAction"

                menubarPath="help/helpEnd"

                id="org.eclipse.help.internal.ui.HelpAction">

            </action>

            <!-- ... other actionSet elements -->

        <action

                label="&Help..."

                icon="icons/search_menu.gif"

                helpContextId="org.eclipse.help.ui.helpSearchMenu"

                   class="org.eclipse.help.ui.internal.OpenHelpSearchPageAction"// callback

                menubarPath="org.eclipse.search.menu/dialogGroup"

                id="org.eclipse.help.ui.OpenHelpSearchPage">

            </action>

        </actionSet>

    </extension>

<!-- ... -->

</plugin>

 

一个回调对象是一个plain old java object(not a plug-in),当扩展点约定中定义的特定事件发生并被主插件识别时,该回调对象将被主插件调用。回调对象的界面由主插件提供。一个回调对象的实现一般是对应于特定extension的自定义类,且由扩展器插件提供。因为回调对象的实现引用了回调接口,因此一般来说和主插件放在同一包中,且扩展器插件一般依赖主插件。

每个回调对象(不同extension-point对应的回调对象)充当一个特定的extension角色,它由XML元素的属性描述,

 

一个主插件设计者创建一个扩展点时,除了在plugin.xml文件中说明扩展点外,还需要在.exsd文件(扩展点规范extension-point schema)中详细定义extension扩展该扩展点的语法。该文件告诉扩展插件的设计者们如何参数化扩展。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值