public class LocalVariablesSorter extends MethodAdapter
MethodAdapter that renumbers local variables in their order of
appearance. This adapter allows one to easily add new local variables to a
method. It may be used by inheriting from this class, but the preferred way
of using it is via delegation: the next visitor in the chain can indeed add
new locals when needed by calling newLocal(clojure.asm.Type) on this adapter (this
requires a reference back to this LocalVariablesSorter).| Modifier and Type | Field and Description |
|---|---|
private boolean |
changed
Indicates if at least one local variable has moved due to remapping.
|
protected int |
firstLocal
Index of the first local variable, after formal parameters.
|
private int[] |
mapping
Mapping from old to new local variable indexes.
|
private java.lang.Object[] |
newLocals
Array used to store stack map local variable types after remapping.
|
protected int |
nextLocal
Index of the next local variable to be created by
newLocal(clojure.asm.Type). |
private static Type |
OBJECT_TYPE |
mv| Constructor and Description |
|---|
LocalVariablesSorter(int access,
java.lang.String desc,
MethodVisitor mv)
Creates a new
LocalVariablesSorter. |
| Modifier and Type | Method and Description |
|---|---|
int |
newLocal(Type type)
Creates a new local variable of the given type.
|
private int |
remap(int var,
int size) |
private int |
remap(int var,
Type type) |
private void |
setFrameLocal(int local,
java.lang.Object type) |
protected void |
setLocalType(int local,
Type type)
Sets the current type of the given local variable.
|
void |
visitFrame(int type,
int nLocal,
java.lang.Object[] local,
int nStack,
java.lang.Object[] stack)
Visits the current state of the local variables and operand stack
elements.
|
void |
visitIincInsn(int var,
int increment)
Visits an IINC instruction.
|
void |
visitLocalVariable(java.lang.String name,
java.lang.String desc,
java.lang.String signature,
Label start,
Label end,
int index)
Visits a local variable declaration.
|
void |
visitMaxs(int maxStack,
int maxLocals)
Visits the maximum stack size and the maximum number of local variables
of the method.
|
void |
visitVarInsn(int opcode,
int var)
Visits a local variable instruction.
|
visitAnnotation, visitAnnotationDefault, visitAttribute, visitCode, visitEnd, visitFieldInsn, visitInsn, visitIntInsn, visitJumpInsn, visitLabel, visitLdcInsn, visitLineNumber, visitLookupSwitchInsn, visitMethodInsn, visitMultiANewArrayInsn, visitParameterAnnotation, visitTableSwitchInsn, visitTryCatchBlock, visitTypeInsnprivate static final Type OBJECT_TYPE
private int[] mapping
private java.lang.Object[] newLocals
protected final int firstLocal
protected int nextLocal
newLocal(clojure.asm.Type).private boolean changed
public LocalVariablesSorter(int access,
java.lang.String desc,
MethodVisitor mv)
LocalVariablesSorter.access - access flags of the adapted method.desc - the method's descriptor (see Type).mv - the method visitor to which this adapter delegates calls.public void visitVarInsn(int opcode,
int var)
MethodVisitorvisitVarInsn in interface MethodVisitorvisitVarInsn in class MethodAdapteropcode - the opcode of the local variable instruction to be visited.
This opcode is either ILOAD, LLOAD, FLOAD, DLOAD, ALOAD, ISTORE,
LSTORE, FSTORE, DSTORE, ASTORE or RET.var - the operand of the instruction to be visited. This operand is
the index of a local variable.public void visitIincInsn(int var,
int increment)
MethodVisitorvisitIincInsn in interface MethodVisitorvisitIincInsn in class MethodAdaptervar - index of the local variable to be incremented.increment - amount to increment the local variable by.public void visitMaxs(int maxStack,
int maxLocals)
MethodVisitorvisitMaxs in interface MethodVisitorvisitMaxs in class MethodAdaptermaxStack - maximum stack size of the method.maxLocals - maximum number of local variables for the method.public void visitLocalVariable(java.lang.String name,
java.lang.String desc,
java.lang.String signature,
Label start,
Label end,
int index)
MethodVisitorvisitLocalVariable in interface MethodVisitorvisitLocalVariable in class MethodAdaptername - the name of a local variable.desc - the type descriptor of this local variable.signature - the type signature of this local variable. May be
null if the local variable type does not use generic
types.start - the first instruction corresponding to the scope of this
local variable (inclusive).end - the last instruction corresponding to the scope of this local
variable (exclusive).index - the local variable's index.public void visitFrame(int type,
int nLocal,
java.lang.Object[] local,
int nStack,
java.lang.Object[] stack)
MethodVisitorV1_6. Opcodes.F_SAME representing frame with exactly the same
locals as the previous frame and with the empty stack.Opcodes.F_SAME1
representing frame with exactly the same locals as the previous frame and
with single value on the stack (nStack is 1 and
stack[0] contains value for the type of the stack item).Opcodes.F_APPEND representing frame with current locals are
the same as the locals in the previous frame, except that additional
locals are defined (nLocal is 1, 2 or 3 and
local elements contains values representing added types).Opcodes.F_CHOP representing frame with current locals are
the same as the locals in the previous frame, except that the last 1-3
locals are absent and with the empty stack (nLocals is 1,
2 or 3). Opcodes.F_FULL representing complete frame
data.visitFrame in interface MethodVisitorvisitFrame in class MethodAdaptertype - the type of this stack map frame. Must be
Opcodes.F_NEW for expanded frames, or
Opcodes.F_FULL, Opcodes.F_APPEND,
Opcodes.F_CHOP, Opcodes.F_SAME or
Opcodes.F_APPEND, Opcodes.F_SAME1 for compressed
frames.nLocal - the number of local variables in the visited frame.local - the local variable types in this frame. This array must not
be modified. Primitive types are represented by
Opcodes.TOP, Opcodes.INTEGER,
Opcodes.FLOAT, Opcodes.LONG,
Opcodes.DOUBLE,Opcodes.NULL or
Opcodes.UNINITIALIZED_THIS (long and double are
represented by a single element). Reference types are represented
by String objects (representing internal names, or type
descriptors for array types), and uninitialized types by Label
objects (this label designates the NEW instruction that created
this uninitialized value).nStack - the number of operand stack elements in the visited frame.stack - the operand stack types in this frame. This array must not
be modified. Its content has the same format as the "local" array.public int newLocal(Type type)
type - the type of the local variable to be created.protected void setLocalType(int local,
Type type)
local - a local variable identifier, as returned by newLocal().type - the type of the value being stored in the local variableprivate void setFrameLocal(int local,
java.lang.Object type)
private int remap(int var,
Type type)
private int remap(int var,
int size)