Package ghidra.app.util.pcode
Class AbstractPcodeFormatter<T,A extends ghidra.app.util.pcode.Appender<T>> 
java.lang.Object
ghidra.app.util.pcode.AbstractPcodeFormatter<T,A> 
- Type Parameters:
- T- the type of this formatter's output, e.g.,- String
- A- the type of the appender
- All Implemented Interfaces:
- PcodeFormatter<T>
- Direct Known Subclasses:
- AttributedStringPcodeFormatter,- PcodeFrame.MyFormatter,- PcodeProgram.MyFormatter,- StringPcodeFormatter
public abstract class AbstractPcodeFormatter<T,A extends ghidra.app.util.pcode.Appender<T>> 
extends Object
implements PcodeFormatter<T>
An abstract p-code formatter which can take a list of p-code ops or op templates and consistently
 format them. The general pattern is to extend this class and specify another class which extends
 an 
AbstractAppender. In most cases, it is only necessary to override
 formatOpTemplate(Appender, OpTpl). Otherwise, most formatting logic is implemented by
 the appender.- See Also:
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionprotected static enumA result instructing the formatter whether or not to continue
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionprotected abstract AcreateAppender(Language language, boolean indent) Create the appender for a formatting invocationprotected voidformatAddress(A appender, AddressSpace addrSpace, ConstTpl offset, ConstTpl size) Format a memory variableprotected voidformatCallOtherName(A appender, VarnodeTpl input0) Format a p-code userop name (CALLOTHER)protected voidformatConstant(A appender, ConstTpl offset, ConstTpl size) Format a constantprotected voidformatInput(A appender, int opcode, int opIndex, VarnodeTpl input) Format an input varnodeprotected booleanformatLabelInput(A appender, VarnodeTpl input0) Try to format a local label (e.g.,instr_next)protected voidformatMemoryInput(A appender, VarnodeTpl input0, VarnodeTpl input1) Format the memory location for a LOAD or STORE opprotected AbstractPcodeFormatter.FormatResultformatOpTemplate(A appender, OpTpl op) Format a single op templateprotected voidformatOutput(A appender, int opcode, VarnodeTpl output) Format an output varnodeprotected voidformatSize(A appender, ConstTpl size) Format a size indicatorformatTemplates(Language language, List<OpTpl> pcodeOpTemplates) Format the p-code op templatesprotected voidformatUnique(A appender, ConstTpl offset, ConstTpl size) Format a unique variableprotected voidformatVarnode(A appender, int opcode, int opIndex, VarnodeTpl vTpl) Format a varnodeprotected voidformatVarnodeNice(A appender, AddressSpace space, ConstTpl offset, ConstTpl size) Format a varnode in nice (non-raw) formprotected voidformatVarnodeRaw(A appender, AddressSpace space, ConstTpl offset, ConstTpl size) Format a varnode in raw formprotected booleanCheck if this formatter is configured to display raw p-codeprotected static booleanisLineLabel(OpTpl template) Check if the given template represents a line labelMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface ghidra.app.util.pcode.PcodeFormatterformatOps, formatOps
- 
Constructor Details- 
AbstractPcodeFormatterpublic AbstractPcodeFormatter()
 
- 
- 
Method Details- 
createAppenderCreate the appender for a formatting invocation- Parameters:
- language- the language of the p-code to format
- indent- indicates whether each line should be indented to accommodate line labels
- Returns:
- the new appender
 
- 
isFormatRawprotected boolean isFormatRaw()Check if this formatter is configured to display raw p-code- Returns:
- true if displaying raw, false otherwise
 
- 
formatTemplatesDescription copied from interface:PcodeFormatterFormat the p-code op templates- Specified by:
- formatTemplatesin interface- PcodeFormatter<T>
- Parameters:
- language- the language generating the p-code
- pcodeOpTemplates- the templates
- Returns:
- the formatted result
 
- 
formatOpTemplateFormat a single op template- Parameters:
- appender- the appender to receive the formatted text
- op- the template to format
- Returns:
- instructions to continue or terminate. The loop in
         formatTemplates(Language, List)is terminated if this method returnsAbstractPcodeFormatter.FormatResult.TERMINATE.
 
- 
formatOutputFormat an output varnode- Parameters:
- appender- the appender to receive the formatted text
- opcode- the op's opcode
- output- the varnode to format
 
- 
formatInputFormat an input varnode- Parameters:
- appender- the appender to receive the formatted text
- opcode- the op's opcode
- opIndex- the operand's index
- input- the varnode to format
 
- 
formatVarnodeFormat a varnode- Parameters:
- appender- the appender to receive the formatted text
- opcode- the op's opcode
- opIndex- the operand's index (-1 is output, 0 is first input)
- vTpl- the varnode to format
 
- 
formatVarnodeNiceFormat a varnode in nice (non-raw) form- Parameters:
- appender- the appender to receive the formatted text
- space- the address space of the varnode
- offset- the offset in the address space
- size- the size in bytes
 
- 
formatVarnodeRawFormat a varnode in raw form- Parameters:
- appender- the appender to receive the formatted text
- space- the address space of the varnode
- offset- the offset in the address space
- size- the size in bytes
 
- 
formatUniqueFormat a unique variable- Parameters:
- appender- the appender to receive the formatted text
- offset- the offset in unique space
- size- the size in bytes
 
- 
formatAddressFormat a memory variable- Parameters:
- appender- the appender to receive the formatted text
- addrSpace- the address space of the variable
- offset- the offset in the address space
- size- the size in bytes
 
- 
formatConstantFormat a constant- Parameters:
- appender- the appender to receive the formatted text
- offset- the value of the constant
- size- the size in bytes
 
- 
formatSizeFormat a size indicator- Parameters:
- appender- the appender to receive the formatted text
- size- the size in bytes
 
- 
formatCallOtherNameFormat a p-code userop name (CALLOTHER)- Parameters:
- appender- the appender to receive the formatted text
- input0- the constant varnode giving the userop id
 
- 
formatLabelInputTry to format a local label (e.g.,instr_next)- Parameters:
- appender- the appender to receive the formatted text
- input0- the relative jump varnode
- Returns:
- true if the varnode was formatted, false if not
 
- 
formatMemoryInputFormat the memory location for a LOAD or STORE op- Parameters:
- appender- the appender to receive the formatted text
- input0- the const varnode giving the address space id
- input1- the varnode giving the address offset
 
- 
isLineLabelCheck if the given template represents a line labelThe PcodeOp.PTRADDop is ordinarily only use in high p-code. We reuse (read "abuse") it to hold a display slot for line labels later referred to inPcodeOp.BRANCHandPcodeOp.CBRANCHops. This method checks if the given op template is one of those placeholders.- Parameters:
- template- the op template
- Returns:
- true if it's a line label
 
 
-