org.eclipse.debug.ui.IDebugModelPresentation Maven / Gradle / Ivy
/*******************************************************************************
* 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);
}