Class Frame
java.lang.Object
org.objectweb.asm.tree.analysis.Frame
A symbolic execution stack frame. A stack frame contains a set of local
variable slots, and an operand stack. Warning: long and double values are
represented by two slots in local variables, and by one slot
in the operand stack.
- Author:
- Eric Bruneton
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidClears the operand stack of this frame.voidexecute(AbstractInsnNode insn, Interpreter interpreter) getLocal(int i) Returns the value of the given local variable.intReturns the maximum number of local variables of this frame.getStack(int i) Returns the value of the given operand stack slot.intReturns the number of values in the operand stack of this frame.Copies the state of the given frame into this frame.booleanMerges this frame with the given frame (case of a RET instruction).booleanmerge(Frame frame, Interpreter interpreter) Merges this frame with the given frame.pop()Pops a value from the operand stack of this frame.voidPushes a value into the operand stack of this frame.voidSets the value of the given local variable.voidSets the expected return type of the analyzed method.toString()Returns a string representation of this frame.
-
Constructor Details
-
Frame
public Frame(int nLocals, int nStack) Constructs a new frame with the given size.- Parameters:
nLocals- the maximum number of local variables of the frame.nStack- the maximum stack size of the frame.
-
Frame
Constructs a new frame that is identical to the given frame.- Parameters:
src- a frame.
-
-
Method Details
-
init
-
setReturn
Sets the expected return type of the analyzed method.- Parameters:
v- the expected return type of the analyzed method, or null if the method returns void.
-
getLocals
public int getLocals()Returns the maximum number of local variables of this frame.- Returns:
- the maximum number of local variables of this frame.
-
getLocal
Returns the value of the given local variable.- Parameters:
i- a local variable index.- Returns:
- the value of the given local variable.
- Throws:
IndexOutOfBoundsException- if the variable does not exist.
-
setLocal
Sets the value of the given local variable.- Parameters:
i- a local variable index.value- the new value of this local variable.- Throws:
IndexOutOfBoundsException- if the variable does not exist.
-
getStackSize
public int getStackSize()Returns the number of values in the operand stack of this frame. Long and double values are treated as single values.- Returns:
- the number of values in the operand stack of this frame.
-
getStack
Returns the value of the given operand stack slot.- Parameters:
i- the index of an operand stack slot.- Returns:
- the value of the given operand stack slot.
- Throws:
IndexOutOfBoundsException- if the operand stack slot does not exist.
-
clearStack
public void clearStack()Clears the operand stack of this frame. -
pop
Pops a value from the operand stack of this frame.- Returns:
- the value that has been popped from the stack.
- Throws:
IndexOutOfBoundsException- if the operand stack is empty.
-
push
Pushes a value into the operand stack of this frame.- Parameters:
value- the value that must be pushed into the stack.- Throws:
IndexOutOfBoundsException- if the operand stack is full.
-
execute
- Throws:
AnalyzerException
-
merge
Merges this frame with the given frame.- Parameters:
frame- a frame.interpreter- the interpreter used to merge values.- Returns:
- true if this frame has been changed as a result of the merge operation, or false otherwise.
- Throws:
AnalyzerException- if the frames have incompatible sizes.
-
merge
Merges this frame with the given frame (case of a RET instruction).- Parameters:
frame- a frameaccess- the local variables that have been accessed by the subroutine to which the RET instruction corresponds.- Returns:
- true if this frame has been changed as a result of the merge operation, or false otherwise.
-
toString
-