All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.eclipse.debug.ui.IDebugModelPresentation Maven / Gradle / Ivy

There is a newer version: 3.18.500
Show newest version
/*******************************************************************************
 * Copyright (c) 2000, 2005 IBM Corporation and others.
 *
 * This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License 2.0
 * which accompanies this distribution, and is available at
 * https://www.eclipse.org/legal/epl-2.0/
 *
 * SPDX-License-Identifier: EPL-2.0
 *
 * Contributors:
 *     IBM Corporation - initial API and implementation
 *******************************************************************************/
package org.eclipse.debug.ui;


import org.eclipse.debug.core.model.IValue;
import org.eclipse.jface.viewers.ILabelProvider;
import org.eclipse.swt.graphics.Image;

/**
 * A debug model presentation is responsible for providing labels, images,
 * and editors associated with debug elements in a specific debug model.
 * Extensions of type org.eclipse.debug.ui.debugModelPresentations implement
 * this interface. Generally, a debug model implementation will also provide a
 * debug model presentation extension to render and display its elements. A debug
 * model presentation is registered for a specific debug model, and is responsible
 * for the presentation elements defined/implemented by that model.
 * 

* A debug model presentation extension is defined in plugin.xml. * Following is an example definition of a debug model presentation extension. *

 * <extension point="org.eclipse.debug.ui.debugModelPresentations">
 *   <debugModelPresentation
 *      id="com.example.debugModelIdentifier"
 *      class="com.example.ExamplePresentation"
 *      detailsViewerConfiguration="com.example.ExampleSourceViewerConfiguration">
 *   </debugModelPresentation>
 * </extension>
 * 
* The attributes are specified as follows: *
    *
  • id specifies the identifier of the debug model this presentation * is responsible for. Corresponds to the model identifier returned from a debug * element - see IDebugElement.getModelIndentifier
  • *
  • class specifies the fully qualified name of the Java class * that implements this interface.
  • *
  • detailsViewerConfiguration optionally specifies the fully qualified name of the Java class * that is an instance of org.eclipse.jface.text.source.SourceViewerConfiguration. * When specified, the source viewer configuration will be used in the "details" area of the * variables and expressions view when displaying the details of an element from the * debug model associated with this debug model presentation. When unspecified, * a default configuration is used.
  • *
*

*

* To allow for an extensible configuration, this interface defines * a setAttribute method. The debug UI plug-in defines * one presentation attribute: *

    *
  • DISPLAY_VARIABLE_TYPE_NAMES - This is a boolean attribute * indicating whether variable elements should be rendered with the declared * type of a variable. For example, a Java debug model presentation would render * an integer as "int x = 3" when true, and "x = 3" * when false.
  • *
*

*

* Clients may define new presentation attributes. For example, a client may wish * to define a "hexadecimal" property to display numeric values in hexadecimal. Implementations * should honor the presentation attributes defined by this interface where possible, * but do not need to honor presentation attributes defined by other clients. * To access the debug model presentation for a debug view, clients should use * IDebugView#getPresentation(String). *

*

* Since 3.1, debug model presentations may optionally implement IColorProvider * and IFontProvider to override default fonts and colors for debug elements. *

*

* Clients may implement this interface. *

* @see org.eclipse.debug.core.model.IDebugElement * @see org.eclipse.jface.viewers.ILabelProvider * @see org.eclipse.debug.ui.IDebugView */ public interface IDebugModelPresentation extends ILabelProvider, ISourcePresentation { /** * Variable type names presentation property (value "org.eclipse.debug.ui.displayVariableTypeNames"). * When DISPLAY_VARIABLE_TYPE_NAMES is set to true, * this label provider should include the reference type of a variable when rendering * variables. When set to false, this label provider * should not include the reference type of a variable when rendering * variables. * @see #setAttribute(String, Object) */ String DISPLAY_VARIABLE_TYPE_NAMES= IDebugUIConstants.PLUGIN_ID + ".displayVariableTypeNames"; //$NON-NLS-1$ /** * Sets a presentation attribute of this label provider. For example, * see the presentation attribute DISPLAY_VARIABLE_TYPE_NAMES * defined by this interface. * * @param attribute the presentation attribute identifier * @param value the value of the attribute */ void setAttribute(String attribute, Object value); /** * Returns an image for the element, or null if a default * image should be used. * * @param element the debug model element * @return an image for the element, or null if a default * image should be used * @see ILabelProvider */ @Override Image getImage(Object element); /** * Returns a label for the element, or null if a default * label should be used. * * @param element the debug model element * @return a label for the element, or null if a default * label should be used * @see ILabelProvider */ @Override String getText(Object element); /** * Computes a detailed description of the given value, reporting * the result to the specified listener. This allows a presentation * to provide extra details about a selected value in the variable detail * portion of the variables view. Since this can be a long-running operation, * the details are reported back to the specified listener asynchronously. * If null is reported, the value's value string is displayed * (IValue.getValueString()). * * @param value the value for which a detailed description * is required * @param listener the listener to report the details to * asynchronously * @since 2.0 */ void computeDetail(IValue value, IValueDetailListener listener); }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy