All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.eclipse.ui.IActionBars Maven / Gradle / Ivy

Go to download

This plug-in contains the bulk of the Workbench implementation, and depends on JFace, SWT, and Core Runtime. It cannot be used independently from org.eclipse.ui. Workbench client plug-ins should not depend directly on this plug-in.

The newest version!
/*******************************************************************************
 * Copyright (c) 2000, 2006 IBM Corporation and others.
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * which accompanies this distribution, and is available at
 * http://www.eclipse.org/legal/epl-v10.html
 *
 * Contributors:
 *     IBM Corporation - initial API and implementation
 *******************************************************************************/
package org.eclipse.ui;

import org.eclipse.jface.action.IAction;
import org.eclipse.jface.action.IMenuManager;
import org.eclipse.jface.action.IStatusLineManager;
import org.eclipse.jface.action.IToolBarManager;
import org.eclipse.ui.services.IServiceLocator;

/**
 * Used by a part to access its menu, toolbar, and status line managers.  
 * 

* Within the workbench each part, editor or view, has a private set of action * bars. This set, which contains a menu, toolbar, and status line, appears * in the local toolbar for a view and in the window for an editor. The view * may provide an implementation for pre-existing actions or add new actions to * the action bars. *

* In a workbench window there are a number of actions which are applicable to * all parts. Some common examples are CUT, COPY and * PASTE. These actions, known as "global actions", are contributed to * the workbench window by the window itself and shared by all parts. The * presentation is owned by the window. The implementation is delegated to the * active part. *

* To participate in the global action design an IWorkbenchPart should * register a handler for each global action which is implemented by the part. This * can be done by calling setGlobalActionHandler. For convenience, the * standard global actions are defined in * org.eclipse.ui.IWorkbenchActionConstants. *

* Additional work is required for the Delete global action. In * this case the accelerator is defined in the menu item text but is not hooked * on the window. This is to support text editors where the Delete * key is functional even when the Delete action is disabled (no text * is selected). An implementation for this accelerator must be defined locally, * in each part, by listening for Delete key events. *

* A part may also contribute new actions to the action bars as required. To do * this, call getMenuManager, getToolBarManager, or * getStatusLineManager as appropriate to get the action target. * Add the action(s) to the target and call update to commit * any changes to the underlying widgets. *

* This interface is not intended to be implemented by clients. *

*/ public interface IActionBars { /** * Clears the global action handler list. *

* Note: Clients who manipulate the global action list are * responsible for calling updateActionBars so that the changes * can be propagated throughout the workbench. *

*/ public void clearGlobalActionHandlers(); /** * Returns the global action handler for the action with the given id. * * @param actionId an action id declared in the registry * @return an action handler which implements the action id, or * null if none is registered * @see IWorkbenchActionConstants * @see #setGlobalActionHandler(String, IAction) */ public IAction getGlobalActionHandler(String actionId); /** * Returns the menu manager. *

* Note: Clients who add or remove items from the returned menu manager are * responsible for calling updateActionBars so that the changes * can be propagated throughout the workbench. *

* * @return the menu manager */ public IMenuManager getMenuManager(); /** * Returns the service locator for these action bars. The locator is found * by looking locally, and then ascending the action bar hierarchy. * * @return The service locator; never null. * @since 3.2 */ public IServiceLocator getServiceLocator(); /** * Returns the status line manager. *

* Note: Clients who add or remove items from the returned status line * manager are responsible for calling updateActionBars so * that the changes can be propagated throughout the workbench. *

* * @return the status line manager */ public IStatusLineManager getStatusLineManager(); /** * Returns the tool bar manager. *

* Note: Clients who add or remove items from the returned tool bar manager are * responsible for calling updateActionBars so that the changes * can be propagated throughout the workbench. *

* * @return the tool bar manager */ public IToolBarManager getToolBarManager(); /** * Sets the global action handler for the action with the given id. *

* Note: Clients who manipulate the global action list are * responsible for calling updateActionBars so that the changes * can be propagated throughout the workbench. *

* * @param actionId an action id declared in the registry * @param handler an action which implements the action id, or * null to clear any existing handler * @see IWorkbenchActionConstants */ public void setGlobalActionHandler(String actionId, IAction handler); /** * Updates the action bars. *

* Clients who add or remove items from the menu, tool bar, or status line * managers should call this method to propagated the changes throughout * the workbench. *

*/ public void updateActionBars(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy