/*******************************************************************************
* Copyright (c) 2010, 2011 Wind River Systems, Inc. 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:
* Wind River Systems - initial API and implementation
*******************************************************************************/
package org.eclipse.tm.internal.tcf.cdt.ui;
import org.eclipse.cdt.debug.core.model.IReverseResumeHandler;
import org.eclipse.cdt.debug.core.model.IReverseStepIntoHandler;
import org.eclipse.cdt.debug.core.model.IReverseStepOverHandler;
import org.eclipse.cdt.debug.core.model.IReverseToggleHandler;
import org.eclipse.cdt.debug.core.model.ISteppingModeTarget;
import org.eclipse.cdt.debug.core.model.IUncallHandler;
import org.eclipse.cdt.debug.internal.core.ICWatchpointTarget;
import org.eclipse.cdt.debug.internal.ui.disassembly.dsf.IDisassemblyBackend;
import org.eclipse.cdt.debug.ui.IPinProvider;
import org.eclipse.cdt.ui.text.c.hover.ICEditorTextHover;
import org.eclipse.core.runtime.IAdapterFactory;
import org.eclipse.debug.core.model.ISuspendResume;
import org.eclipse.tm.internal.tcf.cdt.ui.breakpoints.TCFWatchpointTarget;
import org.eclipse.tm.internal.tcf.cdt.ui.commands.TCFPinViewCommand;
import org.eclipse.tm.internal.tcf.cdt.ui.commands.TCFReverseResumeCommand;
import org.eclipse.tm.internal.tcf.cdt.ui.commands.TCFReverseStepIntoCommand;
import org.eclipse.tm.internal.tcf.cdt.ui.commands.TCFReverseStepOverCommand;
import org.eclipse.tm.internal.tcf.cdt.ui.commands.TCFReverseStepReturnCommand;
import org.eclipse.tm.internal.tcf.cdt.ui.commands.TCFReverseToggleCommand;
import org.eclipse.tm.internal.tcf.cdt.ui.disassembly.TCFDisassemblyBackend;
import org.eclipse.tm.internal.tcf.cdt.ui.hover.TCFDebugTextHover;
import org.eclipse.tm.internal.tcf.cdt.ui.sourcelookup.TCFSourceNotFoundPresentation;
import org.eclipse.tm.internal.tcf.debug.ui.model.ISourceNotFoundPresentation;
import org.eclipse.tm.internal.tcf.debug.ui.model.TCFModel;
import org.eclipse.tm.internal.tcf.debug.ui.model.TCFNode;
import org.eclipse.tm.internal.tcf.debug.ui.model.TCFNodeExecContext;
import org.eclipse.tm.internal.tcf.debug.ui.model.TCFNodeExpression;
import org.eclipse.tm.internal.tcf.debug.ui.model.TCFNodeStackFrame;
@SuppressWarnings({ "rawtypes", "restriction" })
public class TCFNodeAdapterFactory implements IAdapterFactory {
private static final Class<?>[] CLASSES = {
IDisassemblyBackend.class,
ISteppingModeTarget.class,
ISuspendResume.class,
ICEditorTextHover.class,
IReverseToggleHandler.class,
IReverseStepIntoHandler.class,
IReverseStepOverHandler.class,
IReverseResumeHandler.class,
IUncallHandler.class,
IPinProvider.class,
ICWatchpointTarget.class,
ISourceNotFoundPresentation.class
};
private static final TCFSourceNotFoundPresentation fgSourceNotFoundPresentation = new TCFSourceNotFoundPresentation();
public Object getAdapter(Object obj, Class type) {
if (obj instanceof TCFNode) {
final TCFNode node = (TCFNode)obj;
TCFModel model = node.getModel();
if (IDisassemblyBackend.class == type) {
TCFDisassemblyBackend backend = new TCFDisassemblyBackend();
if (backend.supportsDebugContext((TCFNode)obj)) return backend;
}
else if (ISteppingModeTarget.class == type) {
ISteppingModeTarget target = (ISteppingModeTarget)model.getAdapter(type, node);
if (target == null) model.setAdapter(type, target = new TCFSteppingModeTarget(model));
return target;
}
else if (ISuspendResume.class == type) {
TCFNodeExecContext exec = null;
if (node instanceof TCFNodeExecContext) {
exec = (TCFNodeExecContext)node;
}
else if (node instanceof TCFNodeStackFrame) {
exec = (TCFNodeExecContext)node.getParent();
}
if (exec != null) {
return new TCFSuspendResumeAdapter(exec);
}
}
else if (ICEditorTextHover.class == type) {
ICEditorTextHover hover = (ICEditorTextHover)model.getAdapter(type, node);
if (hover == null) model.setAdapter(type, hover = new TCFDebugTextHover());
return hover;
}
else if (IReverseToggleHandler.class == type) {
IReverseToggleHandler handler = (IReverseToggleHandler)model.getAdapter(type, node);
if (handler == null) model.setAdapter(type, handler = new TCFReverseToggleCommand());
return handler;
}
else if (IReverseStepIntoHandler.class == type) {
IReverseStepIntoHandler handler = (IReverseStepIntoHandler)model.getAdapter(type, node);
if (handler == null) model.setAdapter(type, handler = new TCFReverseStepIntoCommand(model));
return handler;
}
else if (IReverseStepOverHandler.class == type) {
IReverseStepOverHandler handler = (IReverseStepOverHandler)model.getAdapter(type, node);
if (handler == null) model.setAdapter(type, handler = new TCFReverseStepOverCommand(model));
return handler;
}
else if (IUncallHandler.class == type) {
IUncallHandler handler = (IUncallHandler)model.getAdapter(type, node);
if (handler == null) model.setAdapter(type, handler = new TCFReverseStepReturnCommand(model));
return handler;
}
else if (IReverseResumeHandler.class == type) {
IReverseResumeHandler handler = (IReverseResumeHandler)model.getAdapter(type, node);
if (handler == null) model.setAdapter(type, handler = new TCFReverseResumeCommand(model));
return handler;
}
else if (IPinProvider.class == type) {
IPinProvider handler = (IPinProvider)model.getAdapter(type, node);
if (handler == null) model.setAdapter(type, handler = new TCFPinViewCommand(model));
return handler;
}
else if (ICWatchpointTarget.class == type) {
if (node instanceof TCFNodeExpression) return new TCFWatchpointTarget((TCFNodeExpression)node);
}
else if (ISourceNotFoundPresentation.class == type) {
return fgSourceNotFoundPresentation;
}
}
return null;
}
public Class[] getAdapterList() {
return CLASSES;
}
}