The Eclipse team is pleased to announce that Eclipse 3.3 is now available for download, along with 21 Eclipse Projects, as part of the Europa coordinated release
http://www.eclipse.org/downloads/
The New and Noteworthy is available here.
http://download.eclipse.org/eclipse/downloads/drops/R-3.3-200706251500/whatsnew/eclipse-news.html
We would like to thank other committers, contributors and community members who contributed to the release, especially the following people
http://www.eclipse.org/eclipse/development/acknowledgements_3_3.html
2007-06-30
Eclipse 3.3 released
2007-06-26
US DoD Gold Disk and Eclipse RCP
I don't know what this is, apart from some security checks that are performed on an application using a "Gold Disk" (CD?) from US Department of Defense.
Does anybody know, what this is? And whether an Eclipse RCP based application can be expected to pass this sort of certification?
If you don't want to comment on this, please feel free to mail me on tonny.madsen@rcp-company.com.
2007-06-20
Eclipse aware Java Obfuscator wanted
There are a number of problem with obfuscation of Java code when using Eclipse RCP:
- Any class that is mentioned in the plugin.xml should either not be obfuscated or the plugin.xml should be changed as well.
- Any Java package that is exported by a plug-in, should not be obfuscated as other plug-ins might depend on these.
Has anybody done this? Any pointers to obfuscation applications and Eclipse plug-ins will be appreciated.
2007-06-19
Using activities for user management
This blog entry will show how to implement this using activities in Eclipse RCP. A demonstration plug-in is found here.
There seems to be at least a couple of possible solutions based on plug-ins: only install the plug-ins relevant for the user or only load the plug-ins that are allowed for the user. Although this is not all that difficult to implement, it is a rather coarse solution. It is not always the case that the functionality of plug-ins can be divided along the same lines as wanted from the security system. It is similar to using a canon to shoot a mosquito...
A much more elegant solution is to use activities - also known as capabilities - for the job as these can be used completely orthogonal to plug-ins: once the activities can be defined, these can be used to restrict just about any contribution of the interface in any plug-in.
Another very nice property of activities, is the fact the almost all of the implementation is confined to the various
plugin.xml
files. Only a very small part of the functionality must go into the Java code itself and even that can be limited to the WorkbenchAdvisor
or a similar place...To use activities you must use the following model:
- Activity: A single activity (or capability)
- Category: An arbitrary set of activities - these are only relevant if you expect to expose the Capabilities preference page to the users, which is very unlikely when activities are used in this use case...
- Pattern: A regular expression for the contributions that are managed via an activity
- Manager: The activity manager
- Identifier: A single ID from a specific plug-in
You must go through the following steps to use the activities in your application.
Defining a new activity
To define a new activity you use the following
org.eclipse.ui.activities/activity
extension:
<extension
point="org.eclipse.ui.activities">
<activity
description="The Support Role"
id="com.rcpcompany.demo.activities.support"
name="Sample action"/>
</extension>
The ID is normally chosen to make it easy to map the capabilities returned by the sign-on server to the internally used IDs. In this case, we assume that the returned token is "support" so it is just a matter of concatenating two strings :-)
Assigning contributions to activities
This is the difficult part, until you find out how to map the different contributions to the ID scheme used in the activity patterns.
Basically you must add a
org.eclipse.ui.activities/activityPatternBinding
extension for each item you want to handle. Although it is possible to use regular expressions to match many IDs at once, this can hardly be recommended as this makes it rather hard to assign IDs to the different contributions used in an RCP application.Given the following definition for a view:
<extension
point="org.eclipse.ui.views">
<view
class="com.rcpcompany.demo.ui.views.History"
id="com.rcpcompany.demo.ui.views.History"
name="History"/>
</extension>
the following definition is used to restrict access to the view based on whether the activity is enabled:
<extension
point="org.eclipse.ui.activities">
<activityPatternBinding
activityId="com.rcpcompany.demo.activities.support"
pattern=".*/com\.rcpcompany\.demo\.ui\.views\.History"/>
</activityPatternBinding>
</extension>
The IDs to use for different contributions is taken from the
id
attribute used in the definition elements.I use one conversion to help avoid some of the work: when a command is used in a
org.eclipse.ui.menus/menuContribution/command
the id
is the same as the command with suffix .mc.something
. As in the following example:
<extension
point="org.eclipse.ui.commands">
<command
description="Shows the name of the current resource"
id="com.rcpcompany.demo.ui.commands.showName"
name="&Show Name">
</command>
</extension>
<extension
point="org.eclipse.ui.menus">
<menuContribution
locationURI="menu:file">
<command
commandId="com.rcpcompany.demo.ui.commands.showName"
id="com.rcpcompany.demo.ui.commands.showName.mc.file">
<visibleWhen>
...
</visibleWhen>
</command>
<command
commandId="org.eclipse.ui.edit.rename"
id="org.eclipse.ui.edit.rename.mc.file">
</command>
</menuContribution>
<menuContribution
locationURI="toolbar:org.eclipse.ui.main.toolbar">
<toolbar
id="com.rcpcompany.demo.ui.toolbars.main.show">
<command
commandId="com.rcpcompany.demo.ui.commands.showName"
id="com.rcpcompany.demo.ui.commands.showName.mc.toolbar.main.show">
</command>
</toolbar>
</menuContribution>
</extension>
<extension
point="org.eclipse.ui.activities">
<activityPatternBinding
activityId="com.rcpcompany.demo.activities.support"
pattern=".*/com\.rcpcompany\.demo\.ui\.commands\.showName(\.mc\..*)?"/>
</activityPatternBinding>
</extension>
Enabling activities
To enable the needed features when the user is logged in, the following code can be used in
WorkbenchAdvitor
:
@Override
public void initialize(IWorkbenchConfigurer configurer) {
super.initialize(configurer);
IWorkbenchActivitySupport activitySupport = configurer.getWorkbench()
.getActivitySupport();
IActivityManager activityManager = activitySupport.getActivityManager();
Set<String> enabledActivities = new HashSet<String>();
String id = "com.rcpcompany.training.demo.activities.activities." + myRole;
if (activityManager.getActivity(id).isDefined()) {
enabledActivities.add(id);
}
activitySupport.setEnabledActivityIds(enabledActivities);
}
Please notice the the code tests whether the role exists before using it. If this is not done, an undeclared activity will be enabled and no parts of the interface will be affected.
And the rest...
There are a number of other things to be done as well depending on the actual application:- If the roles can be updated while the application is running, you must repeat the code above in your listener. Unfortunately, you must also clean up the existing perspectives, views and editors in the workbench. This is particular difficult for editors as this can be dirty or in an inconsistent state where they cannot just be saved...
- If you want to debug what contributions that are visible and not, then use the Capability preference page:
Please note that you also need an activity category in this case...
<extension
point="org.eclipse.ui.preferencePages">
<page
category="org.eclipse.ui.preferencePages.Workbench"
name="Capabilities"
id="org.eclipse.sdk.capabilities"
class="org.eclipse.ui.activities.ActivitiesPreferencePage"/>
</extension> - There can be any number of roles enabled at the same time.
- Roles can depend on other roles, so you can have "support manager" that depends on "support".
- A demonstration plug-in is found here.
2007-06-17
Translating objectContributions
into menuContributions
Consider the following action definition used in Eclipse 3.2.
<extension point="org.eclipse.ui.popupMenus"> <objectContribution adaptable="false" id="com.rcpcompany.demo.providers.ui.objectContributions.ires.general" objectClass="com.rcpcompany.training.demo.core.IRes"> <action class="com.rcpcompany.training.demo.providers.ui.actions.ShowName" icon="icons/ShowName.gif" id="com.rcpcompany.demo.providers.ui.actions.showname" label="Show Name"> </action> <filter name="folder" value="true"> </filter> </objectContribution> </extension>This definition will add a new action with the text "Show Name" to all popup menus if the current selection contains at least one object of the
IRes
interface and this object returns true
for the folder (using an IActionFilter
). It is a rather tense description.For Eclipse 3.3, this description is spread over a number of extension.
First a
commands
extension is used to declare the command itself:<extension point="org.eclipse.ui.commands"> <command description="Shows the name of the current resource" id="com.rcpcompany.training.demo33.providers.ui.commands.showName" name="&Show Name"> </command> </extension>
Then the image of the command must be added:
<extension point="org.eclipse.ui.commandImages"> <image commandId="com.rcpcompany.training.demo33.providers.ui.commands.showName" icon="icons/ShowName.gif"> </image> </extension>
The next thing is to add a handler for the command:
<extension point="org.eclipse.ui.handlers"> <handler class="com.rcpcompany.training.demo33.providers.ui.handlers.ShowName" commandId="com.rcpcompany.training.demo33.providers.ui.commands.showName"> <enabledWhen> <with variable="selection"> <iterate ifEmpty="false" operator="and"> <and> <instanceof value="com.rcpcompany.training.demo33.core.IRes"> </instanceof> <test property="com.rcpcompany.isFolder"> </test> </and> </iterate> </with> </enabledWhen> </handler> </extension>
This is where most of the complexity is in the new implementation: the tense declaration from 3.2 is now rather verbose. Having said that, the new notation also allows for much more complicated stuff than what was possible before. Note that the
IActionFilter
has been replaced with a IPropertyTester
- which is very good, as all properties now need not be in a single test object, but can be distributed over any number of o objects.Last the popup menus must be added to all popup menus:
<extension point="org.eclipse.ui.menus"> <menuContribution locationURI="popup:org.eclipse.ui.popup.any"> <command commandId="com.rcpcompany.training.demo33.providers.ui.commands.showName"> </command> </menuContribution> </extension>
Depending on the small details, there can be some changes to this - e.g. if the command should only be shown when the selection includes the right objects.
So what didn't work? I hadn't added the
iterate
test declaration! And since my selection actually was a StructedSelection
, then the implicit iteration from 3.2 had to be handled explicitly.Having worked with the new notation for a number of days now, I think the new notation is better than the old notation. If you just use a command in a single place, then the new notation will take longer to use, but if the same command is used in at least a few places, then the new notation is faster. With other words: the basic overhead of the new notation is larger than for the old notation...
2007-06-15
Working with the menus
extension point
org.eclipse.ui.menus
extension point in Eclipse 3.3. To do that I first have to get acquainted with the new functionality.The new extension point is basically a replacement of the following extension points from Eclipse 3.2:
org.eclipse.ui.popupMenus/viewerContribution
- Used to add an action to a specific popup menu (usually a context menu or a ruler) of a view or editor
org.eclipse.ui.popupMenus/objectContribution
- Used to add an action to all popup menus when a specific object type is selected
org.eclipse.ui.actionSets/actionSets
- Used to add an action to the top-level menu bar and top-level tool bar
org.eclipse.ui.editorActions/editorContribution
- Used to add an action to a specific editor top-level menu and tool bar
org.eclipse.ui.viewActions/viewContribution
- Used to add an action to a specific view local menu
menus
extension point not only replaces these extension points, but also adds the ability to add stuff to the trim areas and to the status line. Adding to the trim areas was difficult in Eclipse 3.2, whereas adding to the status line could only easily be done in the ActionBarAdvisor
- which made to difficult to use in applications with multiple plug-ins.To add stuff to any menu or tool bar in Eclipse 3.3, you basically needs two things:
- The ID of the menu or tool bar.
- A command defined with the
commands
extension point.
menu:org.eclipse.ui.main.menu
– the top-level menupopup:org.eclipse.ui.any.popup
– all pop-up menustoolbar:org.eclipse.ui.main.toolbar
– the top-level tool bartoolbar:org.eclipse.ui.trim.command1
– the top left trim areatoolbar:org.eclipse.ui.trim.command2
– the top right trim areatoolbar:org.eclipse.ui.trim.vertical1
– the left vertical trim areatoolbar:org.eclipse.ui.trim.vertical2
– the right vertical trim areatoolbar:org.eclipse.ui.trim.status
– the status line trim area
MenuUtil
for constants.So... to add a new top-level menu along with a single sample action you get:
<extension point="org.eclipse.ui.menus"> <menuContribution locationURI="menu:org.eclipse.ui.main.menu?after=additions"> <menu id="com.rcpcompany.demo.menus33.menus.sampleMenu" label="Sample Menu" mnemonic="M"> <command commandId="com.rcpcompany.demo.menus33.commands.sampleCommand" id="com.rcpcompany.demo.menus33.menus.sampleCommand" mnemonic="S"> </command> </menu> </menuContribution> </extension>Notice the locationURI above. This specification contains three parts, as described in the extension point documentation:
[Scheme]:[ID]?[ArgList]
- Scheme - The 'type' of the UI component into which the contributions will be added. It may be either "menu", "popup" or "toolbar". While 'popup' is indeed a form of menu it is provided to allow a distinction between a view's 'chevron' menu (for which we use the "menu" scheme) and its default context menu which, by convention, should be registered using the "popup" scheme.
- ID - This is the id of menu or toolbar into which the contributions should be added. By convention views should use their view id as the id of the root of their chevron and default popup menu. Note that there is no explicit distinction between contributions supporting editors and 'normal' contributions into the Menu Menu or Toolbar; both global contributions and editor contributions would use the "org.eclipse.ui.main.menu" id or "org.eclipse.ui.main.toolbar". A special id used with popup:, "org.eclipse.ui.any.popup", is reserved to handle contributions which are candidates to appear on any (top level) context menu. Note that these contributions are expected to implement a 'visibleWhen' expression sufficient to limit their visibility to appropriate menus
- Query - This field allows fine-grained definition of the specific location within a given menu. It has the form "[placement]=[id]" where placement is one of "before" or "after" and the id is expected to be the id of some IContributionItem in the menu.
Nearly all the needed information about the menu item is picked up from the command definition (and optionally from the
commandImages
extension point) except for the tool tip which for some reason cannot be specified in the command declaration.If you add anything to any of the top-level tool bars (those with the
toolbar
scheme), you must remember that these really are cool bars and you must therefore first add a tool bar before you add the command itself:<extension point="org.eclipse.ui.menus"> <menuContribution locationURI="toolbar:org.eclipse.ui.trim.status?after=BEGIN_GROUP"> <toolbar id="com.rcpcompany.demo.menus33.toolbars.sampleToolbar"> <command commandId="com.rcpcompany.demo.menus33.commands.sampleCommand"> </command> </toolbar> </menuContribution> </extension>
One last thing: Previously it was quite clear that you had to have certain specific stuff in the
ActionBarAdvisor
: if you wanted to use any of the actions from the ActionFactory
, then this must be hard-coded, which for practical reasons meant the menu structure would also be hard-coded.Not so in Eclipse 3.3: here you can just register the needed actions from the
ActionFactory
in ActionBarAdvisor.makeActions(IWorkbenchWindow)
and then declare the rest in the menus
extension point using the proper command IDs. Look in the org.eclipse.ui
plug-in for a list of all the defined IDs.
Eclipse Summit Europe 2007 comming up
If the event is going to be anything like last year in Esslingen, then it is worth your time...
Changes in JFace for Eclipse 3.3 means work for us
- org.eclipse.ui.menus extension point
- This really will help cleaning up the extension point mess from Eclipse 3.2, although the use of commands, handlers and the corresponding declarations will take some getting used to. There are stil some things that cannot be fully declared so the ActionBarAdvisor has not completely disappeared.
- org.eclipse.jface.viewers.ColumnLabelProvider basic label provider
- This label provider together with org.eclipse.jface.viewers.TableViewerColumn enable column-specific label providers and editing support. It is going to be nice to be able to create complete repositories of label providers that can be used everywhere.
- org.eclipse.jface.window.ToolTip tool tip support
- Creating tool tips with an arbitrary content is also very nice in many RCP applications where a rich feed back can be a real time saver for the user.
- org.eclipse.jface.viewers.OwnerDrawLabelProvider
- This new cell label provider (in the same family as ColumnLabelProvider) allows you to draw a cell explicitly. Unfortunately it cannot be used to add complete SWT Controls in cells...
These changes to the training materials in order to be able to show all the new stuff. Just the above changes, takes 3-4 days of changes (including labs).
So I better get started...
2007-06-13
Interesting Interview with Mike Milinkovich
This match what we in The RCP Company hear from our customers: RCP and technologies like GMF, Higgins and BIRT is now so stable that they see no problems in basing their enterprise applications on this platform.At this year's EclipseCon I felt that the amount of interest in RCP had surpassed the amount of interest in the actual IDE. Do you think this is the case, and if so does this change the dynamics of Eclipse's strategy and direction to become more of a general-purpose application platform and less of a development environment?
Milinkovich: Yes, I agree the Eclipse community and the industry as a whole has moved toward viewing Eclipse as an application platform. We are seeing a lot of interest and adoption of RCP and also projects such as Equinox, RAP, and Higgins. However, this is not new as we have had a conscious strategy to move Eclipse beyond just being a Java IDE for several years now. I believe what we are seeing is quite simply that a number of the newer projects within the Eclipse community are becoming more mature and are enjoying greater interest and adoption as a result. The vision for Eclipse has always been about being a complete platform for software development and I think we are well on the way.
Read the full interview at SYS-CON.TV.
2007-06-12
Mylar has been renamed Mylyn
The Mylar project has been renamed! Please see the following for more
information. Also note the new "mylyn-" mailing list addresses and that we
now have a mailing list specific to integrators who are building on and
redistributing Mylar:
https://dev.eclipse.org/mailman/listinfo/mylyn -integrators
Blog entry discussing the rename:
http://tasktop.com/blog/?p=6
FAQ about the rename:
http://www.eclipse.org/mylyn/rename.php
Ask questions and post comments on the following bug report:
191406: rename Mylar project to Mylyn
https://bugs.eclipse.org/bugs/show_bug.cgi?id=191406
Mik
Eclipse 3.3RC4 released
For people who have already downloaded the integration build with timestamp 200706081718, there's no need to download RC4 - it's the same.
2007-06-03
Eclipse 3.3RC3 released
For people who have already downloaded the integration build with timestamp 200706011539, there's no need to download RC3 - it's the same.