Package serp.bytecode
Class MathInstruction
- java.lang.Object
-
- serp.bytecode.Instruction
-
- serp.bytecode.TypedInstruction
-
- serp.bytecode.MathInstruction
-
- All Implemented Interfaces:
BCEntity,VisitAcceptor
public class MathInstruction extends TypedInstruction
One of the math operations defined in theConstantsinterface. Changing the type or operation of the instruction will automatically update the underlying opcode.- Author:
- Abe White
-
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidacceptVisit(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.booleanequalsInstruction(Instruction other)MathInstructions are equal if they have the same operation and type, or the operation and type of either is unset.intgetLogicalStackChange()Return the logical number of stack positions changed by this instruction.intgetOperation()Return the operation for this math instruction; will be one of the math constant defined inConstants, or -1 if unset.intgetStackChange()Return the number of stack positions this instruction pushes or pops during its execution.java.lang.StringgetTypeName()Return the type name for this instruction.MathInstructionsetOperation(int operation)Set the math operation to be performed.TypedInstructionsetType(java.lang.String type)Set the type of this instruction.-
Methods inherited from class serp.bytecode.TypedInstruction
getType, getTypeBC, setType, setType
-
Methods inherited from class serp.bytecode.Instruction
getByteIndex, getClassLoader, getCode, getLineNumber, getName, getOpcode, getPool, getProject, isValid
-
-
-
-
Method Detail
-
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
-
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
-
getTypeName
public java.lang.String 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
public TypedInstruction setType(java.lang.String type)
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
-
setOperation
public MathInstruction setOperation(int operation)
Set the math operation to be performed. This should be one of the math constant defined inConstants.- Returns:
- this instruction, for method chaining
-
getOperation
public int getOperation()
Return the operation for this math instruction; will be one of the math constant defined inConstants, or -1 if unset.
-
equalsInstruction
public boolean equalsInstruction(Instruction other)
MathInstructions are equal if they have the same operation and type, or the operation and type of either is unset.- Overrides:
equalsInstructionin classInstruction
-
acceptVisit
public void acceptVisit(BCVisitor visit)
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
-
-