Package ghidra.app.util.viewer.field
Class SymbolAnnotatedStringHandler
java.lang.Object
ghidra.app.util.viewer.field.SymbolAnnotatedStringHandler
- All Implemented Interfaces:
AnnotatedStringHandler
,ExtensionPoint
An annotated string handler that handles annotations that begin with
SUPPORTED_ANNOTATIONS
. This class expects one string following the annotation
text that is the address or a symbol name. The display text will be that of the symbol that
is referred to by the address or symbol name.-
Field Summary
Fields inherited from interface ghidra.app.util.viewer.field.AnnotatedStringHandler
DUMMY_MOUSE_HANDLER
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionstatic String
convertAnnotationSymbolToAddress
(String[] annotationParts, String rawText, Program program) createAnnotatedString
(AttributedString prototypeString, String[] text, Program program) Creates anFieldElement
based upon the give array of Strings.Returns the String that represents the GUI presence of this optionReturns an example string of how the annotation is usedgetPrototypeString
(String displayText) Returns an example string of how the annotation is usedString[]
Returns the annotation string names that this AnnotatedStringHandler supports (e.g., "symbol", "address", etc...).boolean
handleMouseClick
(String[] annotationParts, Navigatable sourceNavigatable, ServiceProvider serviceProvider) A method that is notified when an annotation is clicked.
-
Constructor Details
-
SymbolAnnotatedStringHandler
public SymbolAnnotatedStringHandler()
-
-
Method Details
-
convertAnnotationSymbolToAddress
-
createAnnotatedString
public AttributedString createAnnotatedString(AttributedString prototypeString, String[] text, Program program) Description copied from interface:AnnotatedStringHandler
Creates anFieldElement
based upon the give array of Strings. The first String in the list is expected to be the annotation tag used to create the annotation. At the very least the array is expected to be comprised of two elements, the annotation and some data. Extra data may be provided as needed by implementing classes.- Specified by:
createAnnotatedString
in interfaceAnnotatedStringHandler
- Parameters:
prototypeString
- The prototypeFieldElement
that dictates the attributes for the newly created string. Implementations may change attributes as needed.text
- An array of Strings used to create theFieldElement
being returned.program
- The program with which the returned string is associated.- Returns:
- An
AnnotatedTextFieldElement
that will be used to render the given text.
-
getSupportedAnnotations
Description copied from interface:AnnotatedStringHandler
Returns the annotation string names that this AnnotatedStringHandler supports (e.g., "symbol", "address", etc...).- Specified by:
getSupportedAnnotations
in interfaceAnnotatedStringHandler
- Returns:
- the annotation string names that this AnnotatedStringHandler supports.
-
getDisplayString
Description copied from interface:AnnotatedStringHandler
Returns the String that represents the GUI presence of this option- Specified by:
getDisplayString
in interfaceAnnotatedStringHandler
- Returns:
- the String to display in GUI components.
-
getPrototypeString
Description copied from interface:AnnotatedStringHandler
Returns an example string of how the annotation is used- Specified by:
getPrototypeString
in interfaceAnnotatedStringHandler
- Returns:
- the example of how this is used.
-
getPrototypeString
Description copied from interface:AnnotatedStringHandler
Returns an example string of how the annotation is used- Specified by:
getPrototypeString
in interfaceAnnotatedStringHandler
- Parameters:
displayText
- The text that may be wrapped, cannot be null- Returns:
- the example of how this is used.
-