Package serp.bytecode
Class CmpInstruction
java.lang.Object
serp.bytecode.Instruction
serp.bytecode.TypedInstruction
serp.bytecode.CmpInstruction
- All Implemented Interfaces:
BCEntity,VisitAcceptor
An instruction comparing two stack values. Examples include
lcmp, fcmpl, etc.- Author:
- Abe White
-
Method Summary
Modifier and TypeMethodDescriptionvoidacceptVisit(BCVisitor visit) Accept a visit from aBCVisitor, calling the appropriate methods to notify the visitor that it has entered this entity, and to provide it with the proper callbacks for each sub-entity owned by this one.intReturn the logical number of stack positions changed by this instruction.intReturn the number that will be placed on the stack if this instruction is of type float or double and one of the operands is NaN.intReturn the number of stack positions this instruction pushes or pops during its execution.Return the type name for this instruction.setNaNValue(int nan) Set the number that will be placed on the stack if this instruction is of type float or double and one of the operands is NaN.Set the type of this instruction.Methods inherited from class serp.bytecode.TypedInstruction
getType, getTypeBC, setType, setTypeMethods inherited from class serp.bytecode.Instruction
equalsInstruction, getByteIndex, getClassLoader, getCode, getLineNumber, getName, getOpcode, getPool, getProject, isValid
-
Method Details
-
getLogicalStackChange
public int getLogicalStackChange()Description copied from class:InstructionReturn the logical number of stack positions changed by this instruction. In other words, ignore weirdness with longs and doubles taking two stack positions.- Overrides:
getLogicalStackChangein classInstruction
-
getStackChange
public int getStackChange()Description copied from class:InstructionReturn the number of stack positions this instruction pushes or pops during its execution.- Overrides:
getStackChangein classInstruction- Returns:
- 0 if the stack is not affected by this instruction, a positive number if it pushes onto the stack, and a negative number if it pops from the stack
-
getTypeName
Description copied from class:TypedInstructionReturn the type name for this instruction. If the type has not been set, this method will return null.- Specified by:
getTypeNamein classTypedInstruction
-
setType
Description copied from class:TypedInstructionSet the type of this instruction. Types that have no direct support will be converted accordingly.- Specified by:
setTypein classTypedInstruction- Returns:
- this instruction, for method chaining
-
getNaNValue
public int getNaNValue()Return the number that will be placed on the stack if this instruction is of type float or double and one of the operands is NaN. For FCMPG or DCMPG, this value will be 1; for FCMPL or DCMPL this value will be -1. For LCMP or if the type is unset, this value will be 0. -
setNaNValue
Set the number that will be placed on the stack if this instruction is of type float or double and one of the operands is NaN. For FCMPG or DCMPG, this value should be 1; for FCMPL or DCMPL this value should be -1. For LCMP, this value should be 0.- Returns:
- this instruction, for method chaining
-
acceptVisit
Description copied from interface:VisitAcceptorAccept a visit from aBCVisitor, calling the appropriate methods to notify the visitor that it has entered this entity, and to provide it with the proper callbacks for each sub-entity owned by this one.- Specified by:
acceptVisitin interfaceVisitAcceptor- Overrides:
acceptVisitin classInstruction
-