/*******************************************************************************
* Copyright (c) 2009, 2011 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.jdt.internal.ui.callhierarchy;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Iterator;
import java.util.List;
import org.eclipse.swt.widgets.TreeItem;
import org.eclipse.jface.action.Action;
import org.eclipse.jface.viewers.ISelection;
import org.eclipse.jface.viewers.IStructuredSelection;
import org.eclipse.ui.ISharedImages;
import org.eclipse.ui.PlatformUI;
import org.eclipse.jdt.core.IMember;
import org.eclipse.jdt.internal.corext.callhierarchy.MethodWrapper;
import org.eclipse.jdt.internal.ui.IJavaHelpContextIds;
import org.eclipse.jdt.internal.ui.JavaPlugin;
/**
* This action removes a single node from the Call Hierarchy view.
*
* @since 3.6
*/
class RemoveFromViewAction extends Action{
/**
* The Call Hierarchy view part.
*/
private CallHierarchyViewPart fPart;
/**
* The Call Hierarchy viewer.
*/
private CallHierarchyViewer fCallHierarchyViewer;
/**
* Creates the hide single node action.
*
* @param part the call hierarchy view part
* @param viewer the call hierarchy viewer
*/
public RemoveFromViewAction(CallHierarchyViewPart part, CallHierarchyViewer viewer) {
fPart= part;
fCallHierarchyViewer= viewer;
setText(CallHierarchyMessages.RemoveFromViewAction_removeFromView_text);
setDescription(CallHierarchyMessages.RemoveFromViewAction_removeFromView_description);
setToolTipText(CallHierarchyMessages.RemoveFromViewAction_removeFromView_tooltip);
PlatformUI.getWorkbench().getHelpSystem().setHelp(this, IJavaHelpContextIds.CALL_HIERARCHY_REMOVE_FROM_VIEW_ACTION);
ISharedImages workbenchImages= JavaPlugin.getDefault().getWorkbench().getSharedImages();
setDisabledImageDescriptor(workbenchImages.getImageDescriptor(ISharedImages.IMG_ELCL_REMOVE_DISABLED));
setImageDescriptor(workbenchImages.getImageDescriptor(ISharedImages.IMG_ELCL_REMOVE));
setHoverImageDescriptor(workbenchImages.getImageDescriptor(ISharedImages.IMG_ELCL_REMOVE));
}
/* (non-Javadoc)
* @see org.eclipse.jface.action.Action#run()
*/
@Override
public void run() {
IMember[] inputElements= fPart.getInputElements();
List<IMember> inputList= new ArrayList<IMember>(Arrays.asList(inputElements));
IMember[] selection= getSelectedElements();
for (int i= 0; i < selection.length; i++) {
if (inputList.contains(selection[i]))
inputList.remove(selection[i]);
}
if (inputList.size() > 0) {
fPart.updateInputHistoryAndDescription(inputElements, inputList.toArray(new IMember[inputList.size()]));
}
TreeItem[] items= fCallHierarchyViewer.getTree().getSelection();
for (int i= 0; i < items.length; i++)
items[i].dispose();
}
/**
* Gets the elements selected in the call hierarchy view part.
*
* @return the elements
* @since 3.7
*/
private IMember[] getSelectedElements() {
ISelection selection= getSelection();
if (selection instanceof IStructuredSelection) {
List<IMember> members= new ArrayList<IMember>();
List<?> elements= ((IStructuredSelection)selection).toList();
for (Iterator<?> iter= elements.iterator(); iter.hasNext();) {
Object obj= iter.next();
if (obj instanceof MethodWrapper) {
MethodWrapper wrapper= (MethodWrapper)obj;
members.add((wrapper).getMember());
}
}
return members.toArray(new IMember[members.size()]);
}
return null;
}
/**
* Gets the selection from the call hierarchy view part.
*
* @return the current selection
*/
private ISelection getSelection() {
return fPart.getSelection();
}
/**
* Checks whether this action can be added for the selected element in the call hierarchy.
*
* @return <code> true</code> if the action can be added, <code>false</code> otherwise
*/
protected boolean canActionBeAdded() {
IStructuredSelection selection= (IStructuredSelection)getSelection();
if (selection.isEmpty())
return false;
Iterator<?> iter= selection.iterator();
while (iter.hasNext()) {
Object element= iter.next();
if (!(element instanceof MethodWrapper))//takes care of '...' node
return false;
}
TreeItem[] items= fCallHierarchyViewer.getTree().getSelection();
for (int k= 0; k < items.length; k++) {
if (!checkForChildren(items[k]))
return false;
}
return true;
}
/**
* Checks whether the children are being fetched for a node recursively.
*
* @param item the parent node
* @return <code>false</code> when children are currently being fetched for a node,
* <code>true</code> otherwise
*/
private boolean checkForChildren(TreeItem item) {
TreeItem[] children= item.getItems();
if (children.length == 1) {
Object data= children[0].getData();
if (!(data instanceof MethodWrapper) && data != null)
return false; // Do not add action if children are still being fetched for that node or if it's only JFace's dummy node.
}
for (int i= 0; i < children.length; i++) {
if (!checkForChildren(children[i]))
return false;
}
return true;
}
}