Package ghidra.program.model.listing
Class ReturnParameterImpl
- java.lang.Object
- 
- ghidra.program.model.listing.ParameterImpl
- 
- ghidra.program.model.listing.ReturnParameterImpl
 
 
- 
 public class ReturnParameterImpl extends ParameterImpl ReturnParameterImplrepresent the function return value. This is special type of parameter whose ordinal is -1 and allows for the use of the 'void' datatype.
- 
- 
Field Summary- 
Fields inherited from class ghidra.program.model.listing.ParameterImplordinal
 - 
Fields inherited from interface ghidra.program.model.listing.ParameterRETURN_NAME, RETURN_ORIDINAL, UNASSIGNED_ORDINAL
 
- 
 - 
Constructor SummaryConstructors Constructor Description ReturnParameterImpl(DataType dataType, int stackOffset, Program program)Construct a return parameter at the specified stack offset.ReturnParameterImpl(DataType dataType, Address storageAddr, Program program)Construct a return parameter with a single varnode at the specified address.ReturnParameterImpl(DataType dataType, Register register, Program program)Construct a return parameter using the specified register.ReturnParameterImpl(DataType dataType, Program program)Construct a return parameter which has no specific storage specified.ReturnParameterImpl(DataType dataType, VariableStorage storage, boolean force, Program program)Construct a return parameter with one or more associated storage elements.ReturnParameterImpl(DataType dataType, VariableStorage storage, Program program)Construct a return parameter with one or more associated storage elements.ReturnParameterImpl(Parameter param, Program program)Construct a return parameter from another.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description intcompareTo(Variable otherVar)booleanequals(java.lang.Object obj)java.lang.StringgetComment()Get the Comment for this variableVarnodegetFirstStorageVarnode()Get the first storage varnode for this variableFunctiongetFunction()Returns the function that contains this Variable.VarnodegetLastStorageVarnode()Get the last storage varnode for this variableintgetLength()Get the length of this variableAddressgetMinAddress()java.lang.StringgetName()Get the Name of this variable or null if not assigned or not-applicableProgramgetProgram()Returns the program that contains this variable or is the intended targetRegistergetRegister()java.util.List<Register>getRegisters()SourceTypegetSource()Get the source of this variableintgetStackOffset()SymbolgetSymbol()VariableStoragegetVariableStorage()Get the variable storage associated with this variable.booleanhasAssignedStorage()inthashCode()booleanhasStackStorage()booleanisCompoundVariable()booleanisEquivalent(Variable otherVar)booleanisMemoryVariable()booleanisRegisterVariable()booleanisStackVariable()booleanisUniqueVariable()booleanisValid()Verify that the variable is valid (i.e., storage is valid and size matches variable data type size)protected booleanisVoidAllowed()voidsetComment(java.lang.String comment)Set the comment for this variablevoidsetDataType(DataType type, boolean align, boolean force, SourceType source)Set the Data Type of this variable.voidsetDataType(DataType type, VariableStorage storage, boolean force, SourceType source)Set the Data Type of this variable and the associated storage whose size matches the data type length.voidsetDataType(DataType type, SourceType source)Set the Data Type of this variable using the default alignment behavior (implementation specific).voidsetName(java.lang.String name, SourceType source)Set the name of this variable.java.lang.StringtoString()- 
Methods inherited from class ghidra.program.model.listing.ParameterImplgetAutoParameterType, getDataType, getFirstUseOffset, getFormalDataType, getOrdinal, hasDefaultName, isAutoParameter, isForcedIndirect
 - 
Methods inherited from class java.lang.Objectclone, finalize, getClass, notify, notifyAll, wait, wait, wait
 - 
Methods inherited from interface ghidra.program.model.listing.VariablegetComment, getFirstStorageVarnode, getFunction, getLastStorageVarnode, getLength, getMinAddress, getName, getProgram, getRegister, getRegisters, getSource, getStackOffset, getSymbol, getVariableStorage, hasAssignedStorage, hasStackStorage, isCompoundVariable, isEquivalent, isMemoryVariable, isRegisterVariable, isStackVariable, isUniqueVariable, isValid, setComment, setDataType, setDataType, setDataType, setName
 
- 
 
- 
- 
- 
Constructor Detail- 
ReturnParameterImplpublic ReturnParameterImpl(Parameter param, Program program) throws InvalidInputException Construct a return parameter from another.- Parameters:
- param- parameter to be copied
- program- target program
- Throws:
- InvalidInputException- if dataType restrictions are violated
 
 - 
ReturnParameterImplpublic ReturnParameterImpl(DataType dataType, Program program) throws InvalidInputException Construct a return parameter which has no specific storage specified.- Parameters:
- dataType- a fixed-length datatype. (NOTE: Should be cloned to program datatype manager prior to determining storage elements since their length may change)
- program- target program
- Throws:
- InvalidInputException- if dataType restrictions are violated
 
 - 
ReturnParameterImplpublic ReturnParameterImpl(DataType dataType, int stackOffset, Program program) throws InvalidInputException Construct a return parameter at the specified stack offset.- Parameters:
- dataType- a fixed-length datatype. (NOTE: Should be cloned to program datatype manager prior to determining storage elements since their length may change)
- stackOffset- stack offset
- program- target program
- Throws:
- InvalidInputException- if dataType restrictions are violated, an invalid storage address is specified, or unable to resolve storage element for specified datatype
 
 - 
ReturnParameterImplpublic ReturnParameterImpl(DataType dataType, Register register, Program program) throws InvalidInputException Construct a return parameter using the specified register.- Parameters:
- dataType- a fixed-length datatype. (NOTE: Should be cloned to program datatype manager prior to determining storage elements since their length may change)
- register- storage register
- program- target program
- Throws:
- InvalidInputException- if dataType restrictions are violated, an invalid storage address is specified, or unable to resolve storage element for specified datatype
 
 - 
ReturnParameterImplpublic ReturnParameterImpl(DataType dataType, Address storageAddr, Program program) throws InvalidInputException Construct a return parameter with a single varnode at the specified address.- Parameters:
- dataType- a fixed-length datatype. (NOTE: Should be cloned to program datatype manager prior to determining storage elements since their length may change)
- storageAddr- storage address or null if no storage has been identified
- program- target program
- Throws:
- InvalidInputException- if dataType restrictions are violated, an invalid storage address is specified, or unable to resolve storage element for specified datatype
 
 - 
ReturnParameterImplpublic ReturnParameterImpl(DataType dataType, VariableStorage storage, Program program) throws InvalidInputException Construct a return parameter with one or more associated storage elements. Storage elements may get slightly modified to adjust for the resolved datatype size.- Parameters:
- dataType- a fixed-length datatype. (NOTE: Should be cloned to program datatype manager prior to determining storage elements since their length may change)
- storage- variable storage or null for unassigned storage
- program- target program
- Throws:
- InvalidInputException- if dataType restrictions are violated, an invalid storage element is specified, or error while resolving storage element for specified datatype
 
 - 
ReturnParameterImplpublic ReturnParameterImpl(DataType dataType, VariableStorage storage, boolean force, Program program) throws InvalidInputException Construct a return parameter with one or more associated storage elements. Storage elements may get slightly modified to adjust for the resolved datatype size.- Parameters:
- dataType- a fixed-length datatype. (NOTE: Should be cloned to program datatype manager prior to determining storage elements since their length may change)
- storage- variable storage or null for unassigned storage
- force- if true storage will be forced even if incorrect size
- program- target program
- Throws:
- InvalidInputException- if dataType restrictions are violated, an invalid storage element is specified, or error while resolving storage element for specified datatype
 
 
- 
 - 
Method Detail- 
isVoidAllowedprotected boolean isVoidAllowed() - Returns:
- true if a zero-sized void type is permitted
 
 - 
isValidpublic final boolean isValid() Description copied from interface:VariableVerify that the variable is valid (i.e., storage is valid and size matches variable data type size)
 - 
getCommentpublic final java.lang.String getComment() Description copied from interface:VariableGet the Comment for this variable- Specified by:
- getCommentin interface- Variable
- Returns:
- the comment
 
 - 
setDataTypepublic void setDataType(DataType type, VariableStorage storage, boolean force, SourceType source) throws InvalidInputException Description copied from interface:VariableSet the Data Type of this variable and the associated storage whose size matches the data type length.NOTE: The storage and source are ignored if the function does not have custom storage enabled. - Specified by:
- setDataTypein interface- Variable
- Parameters:
- type- the data type
- storage- properly sized storage for the new data type
- force- overwrite conflicting variables
- source- variable storage source (used only for function parameters and return)
- Throws:
- InvalidInputException- if data type is not a fixed length or violates storage constraints.
- VariableSizeException- if force is false and data type size causes a conflict with other variables
 
 - 
setDataTypepublic final void setDataType(DataType type, boolean align, boolean force, SourceType source) throws InvalidInputException Description copied from interface:VariableSet the Data Type of this variable. The given dataType must have a fixed length.- Specified by:
- setDataTypein interface- Variable
- Parameters:
- type- the data type
- force- overwrite conflicting variables
- source- signature source
- Throws:
- InvalidInputException- if data type is not a fixed length or violates storage constraints.
- VariableSizeException- if force is false and data type size causes a conflict with other variables
 
 - 
setDataTypepublic void setDataType(DataType type, SourceType source) throws InvalidInputException Description copied from interface:VariableSet the Data Type of this variable using the default alignment behavior (implementation specific). The given dataType must have a fixed length. If contained within a stack-frame, data-type size will be constrained by existing variables (e.g., equivalent to force=false) Note: stack offset will be maintained for stack variables.- Specified by:
- setDataTypein interface- Variable
- Parameters:
- type- the data type
- source- signature source
- Throws:
- InvalidInputException- if data type is not a fixed length or violates storage constraints.
- VariableSizeException- if data type size causes a conflict with other variables
- See Also:
- #setDataType(DataType, boolean)
 
 - 
getFunctionpublic Function getFunction() Description copied from interface:VariableReturns the function that contains this Variable. May be null if the variable is not in a function.- Specified by:
- getFunctionin interface- Variable
 
 - 
getProgrampublic final Program getProgram() Description copied from interface:VariableReturns the program that contains this variable or is the intended target- Specified by:
- getProgramin interface- Variable
- Returns:
- the program.
 
 - 
getLengthpublic final int getLength() Description copied from interface:VariableGet the length of this variable
 - 
getNamepublic final java.lang.String getName() Description copied from interface:VariableGet the Name of this variable or null if not assigned or not-applicable
 - 
getSourcepublic final SourceType getSource() Description copied from interface:VariableGet the source of this variable
 - 
getSymbolpublic final Symbol getSymbol() 
 - 
setCommentpublic void setComment(java.lang.String comment) Description copied from interface:VariableSet the comment for this variable- Specified by:
- setCommentin interface- Variable
- Parameters:
- comment- the comment
 
 - 
setNamepublic void setName(java.lang.String name, SourceType source) throws InvalidInputExceptionDescription copied from interface:VariableSet the name of this variable.- Specified by:
- setNamein interface- Variable
- Parameters:
- name- the name
- source- the source of this variable name
- Throws:
- InvalidInputException- if name contains blank characters, is zero length, or is null
 
 - 
hasAssignedStoragepublic final boolean hasAssignedStorage() - Specified by:
- hasAssignedStoragein interface- Variable
- Returns:
- true if this variable has been assigned storage.  This is equivalent to 
 Variable.getVariableStorage()!= null
 
 - 
getVariableStoragepublic final VariableStorage getVariableStorage() Description copied from interface:VariableGet the variable storage associated with this variable.- Specified by:
- getVariableStoragein interface- Variable
- Returns:
- the variable storage for this variable
 
 - 
getFirstStorageVarnodepublic final Varnode getFirstStorageVarnode() Description copied from interface:VariableGet the first storage varnode for this variable- Specified by:
- getFirstStorageVarnodein interface- Variable
- Returns:
- the first storage varnode associated with this variable
- See Also:
- #getStorageElements()
 
 - 
getLastStorageVarnodepublic final Varnode getLastStorageVarnode() Description copied from interface:VariableGet the last storage varnode for this variable- Specified by:
- getLastStorageVarnodein interface- Variable
- Returns:
- the last storage varnode associated with this variable
- See Also:
- #getStorageElements()
 
 - 
isStackVariablepublic final boolean isStackVariable() - Specified by:
- isStackVariablein interface- Variable
- Returns:
- true if this is a simple variable consisting of a single stack varnode
 which will be returned by either the Variable.getFirstStorageVarnode()orVariable.getLastStorageVarnode()methods. The stack offset can be obtained using:getFirstStorageVarnode().getOffset()
 
 - 
hasStackStoragepublic final boolean hasStackStorage() - Specified by:
- hasStackStoragein interface- Variable
- Returns:
- true if this variable uses simple or compound storage which contains a stack element. If true, the last storage varnode will always be the stack element.
- See Also:
- Variable.getLastStorageVarnode()
 
 - 
isRegisterVariablepublic final boolean isRegisterVariable() - Specified by:
- isRegisterVariablein interface- Variable
- Returns:
- true if this is a simple variable consisting of a single register varnode
 which will be returned by either the Variable.getFirstStorageVarnode()orVariable.getLastStorageVarnode()methods. The register can be obtained using theVariable.getRegister()method.
 
 - 
getRegisterpublic final Register getRegister() - Specified by:
- getRegisterin interface- Variable
- Returns:
- first storage register associated with this variable, else null is returned. A variable with compound storage may have more than one register or other storage in addition to the register returned by this method.
- See Also:
- Variable.isRegisterVariable()
 
 - 
getRegisterspublic final java.util.List<Register> getRegisters() - Specified by:
- getRegistersin interface- Variable
- Returns:
- all storage register(s) associated with this variable, else null is returned if no registers are used. A variable with compound storage may have more than one register or other storage in addition to the register(s) returned by this method.
- See Also:
- Variable.isRegisterVariable(),- Variable.isCompoundVariable()
 
 - 
getMinAddresspublic final Address getMinAddress() - Specified by:
- getMinAddressin interface- Variable
- Returns:
- the minimum address corresponding to the first varnode of this storage
 or null if this is a special empty storage: #BAD_STORAGE,#UNASSIGNED_STORAGE,#VOID_STORAGE
 
 - 
getStackOffsetpublic final int getStackOffset() - Specified by:
- getStackOffsetin interface- Variable
- Returns:
- the stack offset associated with simple stack variable (i.e., Variable.isStackVariable()returns true).
 
 - 
isMemoryVariablepublic final boolean isMemoryVariable() - Specified by:
- isMemoryVariablein interface- Variable
- Returns:
- true if this is a simple variable consisting of a single storage memory element
 which will be returned by either the Variable.getFirstStorageVarnode()orgetStorageElements()methods.
 
 - 
isUniqueVariablepublic final boolean isUniqueVariable() - Specified by:
- isUniqueVariablein interface- Variable
- Returns:
- true if this is a simple variable consisting of a single storage unique/hash element
 which will be returned by either the Variable.getFirstStorageVarnode()orgetStorageElements()methods. The unique hash can be obtained from the storage address offset corresponding to the single storage element.
 
 - 
isCompoundVariablepublic final boolean isCompoundVariable() - Specified by:
- isCompoundVariablein interface- Variable
- Returns:
- true if this variable uses compound storage consisting of two or more storage elements
 which will be returned by the getStorageElements()method. Compound variables will always use a register(s) optionally followed by other storage (i.e., stack).
 
 - 
toStringpublic java.lang.String toString() - Overrides:
- toStringin class- java.lang.Object
 
 - 
equalspublic final boolean equals(java.lang.Object obj) - Overrides:
- equalsin class- java.lang.Object
 
 - 
hashCodepublic int hashCode() - Overrides:
- hashCodein class- java.lang.Object
 
 - 
compareTopublic final int compareTo(Variable otherVar) - Specified by:
- compareToin interface- java.lang.Comparable<Variable>
 
 - 
isEquivalentpublic final boolean isEquivalent(Variable otherVar) - Specified by:
- isEquivalentin interface- Variable
- Returns:
- true if the specified variable is equivalent to this variable
 
 
- 
 
-