/******************************************************************************* * Copyright (c) 2000, 2008 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: * Jesper Kamstrup Linnet (eclipse@kamstrup-linnet.dk) - initial API and implementation * (report 36180: Callers/Callees view) *******************************************************************************/ package org.eclipse.wst.jsdt.internal.ui.callhierarchy; import org.eclipse.core.runtime.IProgressMonitor; import org.eclipse.core.runtime.OperationCanceledException; import org.eclipse.core.runtime.jobs.ISchedulingRule; import org.eclipse.ui.progress.IDeferredWorkbenchAdapter; import org.eclipse.ui.progress.IElementCollector; import org.eclipse.wst.jsdt.internal.corext.callhierarchy.MethodWrapper; import org.eclipse.wst.jsdt.internal.ui.JavaScriptPlugin; public class DeferredMethodWrapper extends MethodWrapperWorkbenchAdapter implements IDeferredWorkbenchAdapter { private final CallHierarchyContentProvider fProvider; /** * A simple job scheduling rule for serializing jobs that shouldn't be run * concurrently. */ private class BatchSimilarSchedulingRule implements ISchedulingRule { public String id; public BatchSimilarSchedulingRule(String id) { this.id = id; } /* * @see org.eclipse.core.runtime.jobs.ISchedulingRule#isConflicting(org.eclipse.core.runtime.jobs.ISchedulingRule) */ public boolean isConflicting(ISchedulingRule rule) { if (rule instanceof BatchSimilarSchedulingRule) { return ((BatchSimilarSchedulingRule) rule).id.equals(id); } return false; } /* * @see org.eclipse.core.runtime.jobs.ISchedulingRule#contains(org.eclipse.core.runtime.jobs.ISchedulingRule) */ public boolean contains(ISchedulingRule rule) { return this == rule; } } DeferredMethodWrapper(CallHierarchyContentProvider provider, MethodWrapper methodWrapper) { super(methodWrapper); this.fProvider = provider; } private Object getCalls(IProgressMonitor monitor) { return getMethodWrapper().getCalls(monitor); } /* * (non-Javadoc) * * @see org.eclipse.ui.progress.IDeferredWorkbenchAdapter#fetchDeferredChildren(java.lang.Object, * org.eclipse.jface.progress.IElementCollector, * org.eclipse.core.runtime.IProgressMonitor) */ public void fetchDeferredChildren(Object object, IElementCollector collector, IProgressMonitor monitor) { try { fProvider.startFetching(); DeferredMethodWrapper methodWrapper = (DeferredMethodWrapper) object; collector.add((Object[]) methodWrapper.getCalls(monitor), monitor); collector.done(); } catch (OperationCanceledException e) { collector.add(new Object[] { TreeTermination.SEARCH_CANCELED }, monitor); } catch (Exception e) { JavaScriptPlugin.log(e); } finally { fProvider.doneFetching(); } } /* * (non-Javadoc) * * @see org.eclipse.ui.progress.IDeferredWorkbenchAdapter#isContainer() */ public boolean isContainer() { return true; } /* * (non-Javadoc) * * @see org.eclipse.ui.progress.IDeferredWorkbenchAdapter#getRule() */ public ISchedulingRule getRule(Object o) { return new BatchSimilarSchedulingRule("org.eclipse.wst.jsdt.ui.callhierarchy.methodwrapper"); //$NON-NLS-1$ } /* * (non-Javadoc) * * @see org.eclipse.ui.model.IWorkbenchAdapter#getChildren(java.lang.Object) */ public Object[] getChildren(Object o) { return this.fProvider.fetchChildren(((DeferredMethodWrapper) o).getMethodWrapper()); } /** * Returns an object which is an instance of the given class associated * with this object. Returns <code>null</code> if no such object can be * found. */ public Object getAdapter(Class adapter) { if (adapter == IDeferredWorkbenchAdapter.class) return this; return null; } }