The visibility of menus, toolbars and their entries can be restricted via core expressions. You add the corresponding attribute in the application model to the ID defined by the org.eclipse.core.expressions.definitions extension point in the plugin.xml file.
To add this extension point to your application, open the plugin.xml file and select the Dependencies tab in the editor. Add the org.eclipse.core.expressions plug-in in the Required Plug-ins section.
Afterwards select the Extensions tab, press the Add button and add the org.eclipse.core.expressions.definitions extension. You define an ID under which the core expression can be referred to in the application model.
Via right-click on the extension you can start building your expression.
The following example can be used to restrict the visibility of a menu entry based on the type of the current selection. You will later learn how to set the current selection. Please note that the variable for the selection is currently called org.eclipse.ui.selection. In Eclipse 3.x this variable is called selection.
<extension
point="org.eclipse.core.expressions.definitions">
<definition
id="com.example.e4.rcp.todo.selectionset">
<with variable="org.eclipse.ui.selection">
<iterate ifEmpty="false" operator="or">
<instanceof value="com.example.e4.rcp.todo.model.Todo">
</instanceof>
</iterate>
</with>
</definition>
</extension>
You can assign this core expression to your menu entry in the application model. It can be used to restrict the visibility of model elements.
This approach is similar to the definition of core expressions in Eclipse 3.x.
The values available for Eclipse 3.x are contained in the ISources interface and documented in the Eclipse core expressions wiki . Eclipse 4 does not always support the same variables, but the wiki documentation might still be helpful.
You can also place values in the IEclipseContext of your application and use these for your visible-when evaluation.
The following code demonstrates an example handler class which places a value for the myactivePartId key in the context (you will learn more about modifying the IEclipseContext later).
@Execute
public void execute(IEclipseContext context) {
// put an example value in the context
context.set("myactivePartId",
"com.example.e4.rcp.todo.part.todooverview");
}
The following shows an example core expression which evaluates to true if an myactivePartId key with the value com.example.e4.rcp.ui.parts.todooverview is found in the context.
<extension
point="org.eclipse.core.expressions.definitions">
<definition
id="com.example.e4.rcp.todo.todooverviewselected">
<with
variable="myactivePartId">
<equals
value="com.example.e4.rcp.todo.part.todooverview">
</equals>
</with>
</definition>
</extension>
This core expression can get assigned to a menu entry and control the visibility.