blob: caee50ce85832d07b08eb17140fdc1b3cc2a368b [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2000, 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
*
*******************************************************************************/
package org.eclipse.dltk.ui.actions;
import org.eclipse.dltk.core.IDLTKLanguageToolkit;
import org.eclipse.dltk.internal.ui.editor.ScriptEditor;
import org.eclipse.dltk.internal.ui.search.SearchMessages;
import org.eclipse.dltk.ui.DLTKUIPlugin;
import org.eclipse.dltk.ui.PreferenceConstants;
import org.eclipse.jface.action.GroupMarker;
import org.eclipse.jface.action.IMenuManager;
import org.eclipse.jface.action.MenuManager;
import org.eclipse.ui.IActionBars;
import org.eclipse.ui.IViewPart;
import org.eclipse.ui.IWorkbenchSite;
import org.eclipse.ui.actions.ActionContext;
import org.eclipse.ui.actions.ActionGroup;
import org.eclipse.ui.part.Page;
import org.eclipse.ui.texteditor.ITextEditorActionConstants;
/**
* Action group that adds the Script search actions to a context menu and
* the global menu bar.
*
* <p>
* This class may be instantiated; it is not intended to be subclassed.
* </p>
*
*/
public class SearchActionGroup extends ActionGroup {
private ScriptEditor fEditor;
private ReferencesSearchGroup fReferencesGroup;
//private ReadReferencesSearchGroup fReadAccessGroup;
//private WriteReferencesSearchGroup fWriteAccessGroup;
private DeclarationsSearchGroup fDeclarationsGroup;
//private ImplementorsSearchGroup fImplementorsGroup;
//private OccurrencesSearchGroup fOccurrencesGroup;
/**
* Creates a new <code>JavaSearchActionGroup</code>. The group
* requires that the selection provided by the part's selection provider
* is of type <code>org.eclipse.jface.viewers.IStructuredSelection</code>.
*
* @param part the view part that owns this action group
* @param toolkit
*/
public SearchActionGroup(IViewPart part, IDLTKLanguageToolkit toolkit) {
this(part.getViewSite(), toolkit);
}
/**
* Creates a new <code>JavaSearchActionGroup</code>. The group
* requires that the selection provided by the page's selection provider
* is of type <code>org.eclipse.jface.viewers.IStructuredSelection</code>.
*
* @param page the page that owns this action group
*/
public SearchActionGroup(Page page, IDLTKLanguageToolkit toolkit) {
this(page.getSite(), toolkit);
}
/**
* Note: This constructor is for internal use only. Clients should not call this constructor.
* @param editor the Script editor
*/
public SearchActionGroup(ScriptEditor editor) {
fEditor= editor;
fReferencesGroup= new ReferencesSearchGroup(fEditor, fEditor.getLanguageToolkit());
//fReadAccessGroup= new ReadReferencesSearchGroup(fEditor);
//fWriteAccessGroup= new WriteReferencesSearchGroup(fEditor);
fDeclarationsGroup= new DeclarationsSearchGroup(fEditor, fEditor.getLanguageToolkit());
//fImplementorsGroup= new ImplementorsSearchGroup(fEditor);
//fOccurrencesGroup= new OccurrencesSearchGroup(fEditor);
}
private SearchActionGroup(IWorkbenchSite site, IDLTKLanguageToolkit toolkit) {
fReferencesGroup= new ReferencesSearchGroup(site, toolkit);
//fReadAccessGroup= new ReadReferencesSearchGroup(site);
//fWriteAccessGroup= new WriteReferencesSearchGroup(site);
fDeclarationsGroup= new DeclarationsSearchGroup(site, toolkit);
//fImplementorsGroup= new ImplementorsSearchGroup(site);
//fOccurrencesGroup= new OccurrencesSearchGroup(site);
}
/*
* Method declared on ActionGroup.
*/
public void setContext(ActionContext context) {
fReferencesGroup.setContext(context);
fDeclarationsGroup.setContext(context);
//fImplementorsGroup.setContext(context);
//fReadAccessGroup.setContext(context);
//fWriteAccessGroup.setContext(context);
//fOccurrencesGroup.setContext(context);
}
/*
* Method declared on ActionGroup.
*/
public void fillActionBars(IActionBars actionBar) {
super.fillActionBars(actionBar);
fReferencesGroup.fillActionBars(actionBar);
fDeclarationsGroup.fillActionBars(actionBar);
//fImplementorsGroup.fillActionBars(actionBar);
//fReadAccessGroup.fillActionBars(actionBar);
//fWriteAccessGroup.fillActionBars(actionBar);
//fOccurrencesGroup.fillActionBars(actionBar);
}
/*
* Method declared on ActionGroup.
*/
public void fillContextMenu(IMenuManager menu) {
super.fillContextMenu(menu);
if(DLTKUIPlugin.getDefault().getPreferenceStore().getBoolean(PreferenceConstants.SEARCH_USE_REDUCED_MENU)) {
fReferencesGroup.fillContextMenu(menu);
fDeclarationsGroup.fillContextMenu(menu);
// if (fEditor == null) {
// fImplementorsGroup.fillContextMenu(menu);
// fReadAccessGroup.fillContextMenu(menu);
// fWriteAccessGroup.fillContextMenu(menu);
// }
} else {
IMenuManager target= menu;
IMenuManager searchSubMenu= null;
if (fEditor != null) {
String groupName= SearchMessages.group_search;
searchSubMenu= new MenuManager(groupName, ITextEditorActionConstants.GROUP_FIND);
searchSubMenu.add(new GroupMarker(ITextEditorActionConstants.GROUP_FIND));
target= searchSubMenu;
}
fReferencesGroup.fillContextMenu(target);
fDeclarationsGroup.fillContextMenu(target);
//fImplementorsGroup.fillContextMenu(target);
//fReadAccessGroup.fillContextMenu(target);
//fWriteAccessGroup.fillContextMenu(target);
// if (searchSubMenu != null) {
// fOccurrencesGroup.fillContextMenu(target);
// searchSubMenu.add(new Separator());
// }
// no other way to find out if we have added items.
if (searchSubMenu != null && searchSubMenu.getItems().length > 2) {
menu.appendToGroup(ITextEditorActionConstants.GROUP_FIND, searchSubMenu);
}
}
}
/*
* Method declared on ActionGroup.
*/
public void dispose() {
fReferencesGroup.dispose();
fDeclarationsGroup.dispose();
//fImplementorsGroup.dispose();
//fReadAccessGroup.dispose();
//fWriteAccessGroup.dispose();
//fOccurrencesGroup.dispose();
super.dispose();
}
}