Package ghidra.pcode.emu.jit.op
Record Class JitCatenateOp
java.lang.Object
java.lang.Record
ghidra.pcode.emu.jit.op.JitCatenateOp
- Record Components:
- out- the use-def variable node for the output
- parts- the inputs to be concatenated
- All Implemented Interfaces:
- JitDefOp,- JitOp,- JitSyntheticOp
public record JitCatenateOp(JitOutVar out, List<JitVal> parts)
extends Record
implements JitDefOp, JitSyntheticOp
The synthetic use-def node for concatenation.
 
 These are synthesized when memory/register access patterns cause multiple use-def variable nodes
 to be "read" at the same time. E.g., consider AL and AH to be written and then
 AX read.
- 
Constructor SummaryConstructorsConstructorDescriptionJitCatenateOp(JitOutVar out, List<JitVal> parts) Compact constructor for validation
- 
Method SummaryModifier and TypeMethodDescriptionfinal booleanIndicates whether some other object is "equal to" this one.final inthashCode()Returns a hash code value for this object.inputs()The input operand use-def nodes in some defined orderiterParts(boolean bigEndian) Iterate over the parts from most to least significantvoidlink()Add this op to theJitVal.uses()of each input operand, and (if applicable) set theJitOutVar.definition()of the output operand to this op.out()Returns the value of theoutrecord component.parts()Returns the value of thepartsrecord component.partType()We'd like every part to be anint.final StringtoString()Returns a string representation of this record class.type()The required type behavior for the outputtypeFor(int position) Get the required type behavior for the input at the given position inJitOp.inputs()voidunlink()Remove this op from theJitVal.uses()of each input operand, and (if applicable) unset theJitOutVar.definition()of the output operand.Methods inherited from class java.lang.Objectclone, finalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface ghidra.pcode.emu.jit.op.JitDefOpcanBeRemovedMethods inherited from interface ghidra.pcode.emu.jit.op.JitSyntheticOpop
- 
Constructor Details- 
JitCatenateOpCompact constructor for validation- Parameters:
- out- the use-def variable node for the output
- parts- the inputs to be concatenated
 
 
- 
- 
Method Details- 
linkpublic void link()Description copied from interface:JitOpAdd this op to theJitVal.uses()of each input operand, and (if applicable) set theJitOutVar.definition()of the output operand to this op.
- 
unlinkpublic void unlink()Description copied from interface:JitOpRemove this op from theJitVal.uses()of each input operand, and (if applicable) unset theJitOutVar.definition()of the output operand.
- 
iterPartsIterate over the parts from most to least significant- Parameters:
- bigEndian- the byte order off the machine
- Returns:
- an iterable over the parts
 
- 
inputsDescription copied from interface:JitOpThe input operand use-def nodes in some defined order
- 
typeForDescription copied from interface:JitOpGet the required type behavior for the input at the given position inJitOp.inputs()
- 
partTypeWe'd like every part to be anint.- Returns:
- JitTypeBehavior.INTEGER
 
- 
typeDescription copied from interface:JitDefOpThe required type behavior for the output
- 
toStringReturns a string representation of this record class. The representation contains the name of the class, followed by the name and value of each of the record components.
- 
hashCodepublic final int hashCode()Returns a hash code value for this object. The value is derived from the hash code of each of the record components.
- 
equalsIndicates whether some other object is "equal to" this one. The objects are equal if the other object is of the same class and if all the record components are equal. All components in this record class are compared withObjects::equals(Object,Object).
- 
outReturns the value of theoutrecord component.
- 
partsReturns the value of thepartsrecord component.- Returns:
- the value of the partsrecord component
 
 
-