org.eclipse.ui.menus.IMenuService Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of workbench Show documentation
Show all versions of workbench Show documentation
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) 2005, 2007 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.menus;
import org.eclipse.core.expressions.IEvaluationContext;
import org.eclipse.jface.action.ContributionManager;
import org.eclipse.ui.services.IServiceWithSources;
/**
*
* Provides services related to the menu architecture within the workbench. It
* can be used to contribute additional items to the menu, tool bar and status
* line.
*
*
* This interface should not be implemented or extended by clients.
*
*
* @since 3.3
*/
public interface IMenuService extends IServiceWithSources {
/**
* Contribute and initialize the contribution factory. This should only be
* called once per factory. After the call, the factory should be treated as
* an unmodifiable object.
*
* Note: In 3.3M4, this will make the factory available for any
* following calls to
* {@link #populateContributionManager(ContributionManager, String)}, but
* it will not add those contributions to already populated managers.
*
*
* @param factory
* the contribution factory. Must not be null
*/
public void addContributionFactory(AbstractContributionFactory factory);
/**
* Remove the contributed factory from the menu service. If the factory is
* not contained by this service, this call does nothing.
*
* Note:In 3.3M4, this factory will no longer be called during
* {@link #populateContributionManager(ContributionManager, String)} calls,
* but outstanding contributions will not be removed from populated
* contribution managers.
*
*
* @param factory
* the contribution factory to remove. Must not be
* null
.
*/
public void removeContributionFactory(AbstractContributionFactory factory);
/**
* Populate a ContributionManager
at the specified starting
* location with a set of IContributionItems
s. It applies
* AbstractContributionFactory
s that are stored against the
* provided location.
*
* @param mgr
* The ContributionManager to populate
* @param location
* The starting location to begin populating this contribution
* manager. The format is the Menu API URI format.
* @see #releaseContributions(ContributionManager)
*/
public void populateContributionManager(ContributionManager mgr,
String location);
/**
* Before calling dispose() on a ContributionManager populated by the menu
* service, you must inform the menu service to release its contributions.
* This takes care of unregistering any IContributionItems that have their
* visibleWhen clause managed by this menu service.
*
* @param mgr
* The manager that was populated by a call to
* {@link #populateContributionManager(ContributionManager, String)}
*/
public void releaseContributions(ContributionManager mgr);
/**
* Get the current state of eclipse as seen by the menu service.
*
* @return an IEvaluationContext containing state variables.
*
* @see org.eclipse.ui.ISources
*/
public IEvaluationContext getCurrentState();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy