Package serp.bytecode
Class StackInstruction
java.lang.Object
serp.bytecode.Instruction
serp.bytecode.TypedInstruction
serp.bytecode.StackInstruction
- All Implemented Interfaces:
BCEntity,VisitAcceptor
Represents an instruction that manipulates the stack of the current
frame. Using the
setType(java.lang.String) methods is a hint about the type being
manipulated that might cause this instruction to use the wide version
of the opcode it represents (if manipulating a long or double). This
saves the developer from having to decide at compile time whether to
use pop or pop2, 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 number of stack positions this instruction pushes or pops during its execution.This method will always return null; useisWide()to determine if this is pop2, dup2, etc.booleanisWide()Return whether to use the wide form of the current opcode for operations on longs or doubles.Set the type of this instruction.setWide(boolean wide) Set whether to use the wide form of the current opcode for operations on longs or doubles.Methods inherited from class serp.bytecode.TypedInstruction
getType, getTypeBC, setType, setTypeMethods inherited from class serp.bytecode.Instruction
equalsInstruction, getByteIndex, getClassLoader, getCode, getLineNumber, getLogicalStackChange, getName, getOpcode, getPool, getProject, isValid
-
Method Details
-
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
This method will always return null; useisWide()to determine if this is pop2, dup2, etc.- 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
-
isWide
public boolean isWide()Return whether to use the wide form of the current opcode for operations on longs or doubles. -
setWide
Set whether to use the wide form of the current opcode for operations on longs or doubles.- 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
-