visitParameter
)* [ visitAnnotationDefault
] ( visitAnnotation
|
visitAnnotableParameterCount
| visitParameterAnnotation
| visitTypeAnnotation
| visitAttribute
)* [ visitCode
( visitFrame
|
visit<i>X</i>Insn
| visitLabel
| visitInsnAnnotation
| visitTryCatchBlock
| visitTryCatchAnnotation
| visitLocalVariable
| visitLocalVariableAnnotation
| visitLineNumber
)* visitMaxs
] visitEnd
.
In addition, the visit<i>X</i>Insn
and visitLabel
methods must be called in the
sequential order of the bytecode instructions of the visited code, visitInsnAnnotation
must be called after the annotated instruction, visitTryCatchBlock
must be called
before the labels passed as arguments have been visited, visitTryCatchBlockAnnotation
must be called after the corresponding try catch block has
been visited, and the visitLocalVariable
, visitLocalVariableAnnotation
and visitLineNumber
methods must be called after the labels passed as arguments have been
visited.
Modifier and Type | Field and Description |
---|---|
protected final int | api
The ASM API version implemented by this visitor. |
protected MethodVisitor | mv
The method visitor to which this visitor must delegate method calls. |
private static final String |
Access | Constructor and Description |
---|---|
protected | MethodVisitor(final int
the ASM API version implemented by this visitor. Must be one of the api)ASM x values in Opcodes .Constructs a new |
protected | MethodVisitor(final int
the ASM API version implemented by this visitor. Must be one of the api, final MethodVisitor ASM x values in Opcodes .the method visitor to which this visitor must delegate method calls. May
be null. methodVisitor)Constructs a new |
Modifier and Type | Method and Description |
---|---|
public MethodVisitor | Returns: the method visitor to which this visitor must delegate method calls, or null.The method visitor to which this visitor must delegate method calls. |
public void | visitAnnotableParameterCount(final int
the number of method parameters than can have annotations. This number
must be less or equal than the number of parameter types in the method descriptor. It can
be strictly less when a method has synthetic parameters and when these parameters are
ignored when computing parameter indices for the purpose of parameter annotations (see
https://docs.oracle.com/javase/specs/jvms/se9/html/jvms-4.html#jvms-4.7.18). parameterCount, final boolean true to define the number of method parameters that can have
annotations visible at runtime, false to define the number of method parameters
that can have annotations invisible at runtime. visible)Visits the number of method parameters that can have annotations. |
public AnnotationVisitor | Returns: a visitor to visit the annotation values, or null if this visitor is not interested in visiting this annotation.the class descriptor of the annotation class. descriptor, final boolean true if the annotation is visible at runtime. visible)Visits an annotation of this method. |
public AnnotationVisitor | Returns: a visitor to the visit the actual default value of this annotation interface method, or null if this visitor is not interested in visiting this default value. The 'name' parameters passed to the methods of this annotation visitor are ignored. Moreover, exactly one visit method must be called on this annotation visitor, followed by visitEnd.Visits the default value of this annotation interface method. |
public void | visitAttribute(final Attribute
an attribute. attribute)Visits a non standard attribute of this method. |
public void | |
public void | |
public void | visitFieldInsn(final int
the opcode of the type instruction to be visited. This opcode is either
GETSTATIC, PUTSTATIC, GETFIELD or PUTFIELD. opcode, final String the internal name of the field's owner class (see owner, final String Type#getInternalName() ).the field's name. name, final String the field's descriptor (see descriptor)Type ).Visits a field instruction. |
public void | visitFrame(final int
the type of this stack map frame. Must be type, final int 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.the number of local variables in the visited frame. Long and double values
count for one variable. numLocal, final Object[] the local variable types in this frame. This array must not be modified. Primitive
types are represented by local, final int 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, see Type#getInternalName() ), and uninitialized types by Label objects (this label designates
the NEW instruction that created this uninitialized value).the number of operand stack elements in the visited frame. Long and double
values count for one stack element. numStack, final Object[] the operand stack types in this frame. This array must not be modified. Its
content has the same format as the "local" array. stack)Visits the current state of the local variables and operand stack elements. |
public void | visitIincInsn(final int
index of the local variable to be incremented. varIndex, final int amount to increment the local variable by. increment)Visits an IINC instruction. |
public void | visitInsn(final int
the opcode of the instruction to be visited. This opcode is either NOP,
ACONST_NULL, ICONST_M1, ICONST_0, ICONST_1, ICONST_2, ICONST_3, ICONST_4, ICONST_5,
LCONST_0, LCONST_1, FCONST_0, FCONST_1, FCONST_2, DCONST_0, DCONST_1, IALOAD, LALOAD,
FALOAD, DALOAD, AALOAD, BALOAD, CALOAD, SALOAD, IASTORE, LASTORE, FASTORE, DASTORE,
AASTORE, BASTORE, CASTORE, SASTORE, POP, POP2, DUP, DUP_X1, DUP_X2, DUP2, DUP2_X1, DUP2_X2,
SWAP, IADD, LADD, FADD, DADD, ISUB, LSUB, FSUB, DSUB, IMUL, LMUL, FMUL, DMUL, IDIV, LDIV,
FDIV, DDIV, IREM, LREM, FREM, DREM, INEG, LNEG, FNEG, DNEG, ISHL, LSHL, ISHR, LSHR, IUSHR,
LUSHR, IAND, LAND, IOR, LOR, IXOR, LXOR, I2L, I2F, I2D, L2I, L2F, L2D, F2I, F2L, F2D, D2I,
D2L, D2F, I2B, I2C, I2S, LCMP, FCMPL, FCMPG, DCMPL, DCMPG, IRETURN, LRETURN, FRETURN,
DRETURN, ARETURN, RETURN, ARRAYLENGTH, ATHROW, MONITORENTER, or MONITOREXIT. opcode)Visits a zero operand instruction. |
public AnnotationVisitor | Returns: a visitor to visit the annotation values, or null if this visitor is not interested in visiting this annotation.a reference to the annotated type. The sort of this type reference must be
typeRef, final TypePath TypeReference#INSTANCEOF , TypeReference#NEW , TypeReference#CONSTRUCTOR_REFERENCE , TypeReference#METHOD_REFERENCE , TypeReference#CAST , TypeReference#CONSTRUCTOR_INVOCATION_TYPE_ARGUMENT , TypeReference#METHOD_INVOCATION_TYPE_ARGUMENT , TypeReference#CONSTRUCTOR_REFERENCE_TYPE_ARGUMENT , or TypeReference#METHOD_REFERENCE_TYPE_ARGUMENT . See TypeReference .the path to the annotated type argument, wildcard bound, array element type, or
static inner type within 'typeRef'. May be null if the annotation targets
'typeRef' as a whole. typePath, final String the class descriptor of the annotation class. descriptor, final boolean true if the annotation is visible at runtime. visible)Visits an annotation on an instruction. |
public void | visitIntInsn(final int
the opcode of the instruction to be visited. This opcode is either BIPUSH, SIPUSH
or NEWARRAY. opcode, final int the operand of the instruction to be visited. operand)When opcode is BIPUSH, operand value should be between Byte.MIN_VALUE and Byte.MAX_VALUE. When opcode is SIPUSH, operand value should be between Short.MIN_VALUE and Short.MAX_VALUE. When opcode is NEWARRAY, operand value should be one of Opcodes#T_BOOLEAN , Opcodes#T_CHAR , Opcodes#T_FLOAT , Opcodes#T_DOUBLE , Opcodes#T_BYTE ,
Opcodes#T_SHORT , Opcodes#T_INT or Opcodes#T_LONG .Visits an instruction with a single int operand. |
public void | |
public void | visitJumpInsn(final int
the opcode of the type instruction to be visited. This opcode is either IFEQ,
IFNE, IFLT, IFGE, IFGT, IFLE, IF_ICMPEQ, IF_ICMPNE, IF_ICMPLT, IF_ICMPGE, IF_ICMPGT,
IF_ICMPLE, IF_ACMPEQ, IF_ACMPNE, GOTO, JSR, IFNULL or IFNONNULL. opcode, final Label the operand of the instruction to be visited. This operand is a label that
designates the instruction to which the jump instruction may jump. label)Visits a jump instruction. |
public void | |
public void | visitLdcInsn(final Object
the constant to be loaded on the stack. This parameter must be a non null value)Integer , a Float , a Long , a Double , a String , a Type of OBJECT or ARRAY sort for .class constants, for classes whose version is
49, a Type of METHOD sort for MethodType, a Handle for MethodHandle
constants, for classes whose version is 51 or a ConstantDynamic for a constant
dynamic for classes whose version is 55.Visits a LDC instruction. |
public void | visitLineNumber(final int
a line number. This number refers to the source file from which the class was
compiled. line, final Label the first instruction corresponding to this line number. start)Visits a line number declaration. |
public void | visitLocalVariable(final String
the name of a local variable. name, final String the type descriptor of this local variable. descriptor, final String the type signature of this local variable. May be null if the local
variable type does not use generic types. signature, final Label the first instruction corresponding to the scope of this local variable
(inclusive). start, final Label the last instruction corresponding to the scope of this local variable (exclusive). end, final int the local variable's index. index)Visits a local variable declaration. |
public AnnotationVisitor | Returns: a visitor to visit the annotation values, or null if this visitor is not interested in visiting this annotation.a reference to the annotated type. The sort of this type reference must be
typeRef, final TypePath TypeReference#LOCAL_VARIABLE or TypeReference#RESOURCE_VARIABLE . See TypeReference .the path to the annotated type argument, wildcard bound, array element type, or
static inner type within 'typeRef'. May be null if the annotation targets
'typeRef' as a whole. typePath, final Label[] the fist instructions corresponding to the continuous ranges that make the scope
of this local variable (inclusive). start, final Label[] the last instructions corresponding to the continuous ranges that make the scope of
this local variable (exclusive). This array must have the same size as the 'start' array. end, final int[] the local variable's index in each range. This array must have the same size as
the 'start' array. index, final String the class descriptor of the annotation class. descriptor, final boolean true if the annotation is visible at runtime. visible)Visits an annotation on a local variable type. |
public void | visitLookupSwitchInsn(final Label
beginning of the default handler block. dflt, final int[] the values of the keys. keys, final Label[] beginnings of the handler blocks. labels)labels[i] is the beginning of the
handler block for the keys[i] key.Visits a LOOKUPSWITCH instruction. |
public void | visitMaxs(final int
maximum stack size of the method. maxStack, final int maximum number of local variables for the method. maxLocals)Visits the maximum stack size and the maximum number of local variables of the method. |
public void | visitMethodInsn(final int
the opcode of the type instruction to be visited. This opcode is either
INVOKEVIRTUAL, INVOKESPECIAL, INVOKESTATIC or INVOKEINTERFACE. opcode, final String the internal name of the method's owner class (see owner, final String Type#getInternalName() ).the method's name. name, final String the method's descriptor (see descriptor)Type ).
Deprecated
use
Visits a method instruction.
visitMethodInsn(int, String, String, String, boolean) instead.
|
public void | visitMethodInsn(final int
the opcode of the type instruction to be visited. This opcode is either
INVOKEVIRTUAL, INVOKESPECIAL, INVOKESTATIC or INVOKEINTERFACE. opcode, final String the internal name of the method's owner class (see owner, final String Type#getInternalName() ).the method's name. name, final String the method's descriptor (see descriptor, final boolean Type ).if the method's owner class is an interface. isInterface)Visits a method instruction. |
public void | visitMultiANewArrayInsn(final String
an array type descriptor (see descriptor, final int Type ).the number of dimensions of the array to allocate. numDimensions)Visits a MULTIANEWARRAY instruction. |
public void | visitParameter(final String
parameter name or null if none is provided. name, final int the parameter's access flags, only access)ACC_FINAL , ACC_SYNTHETIC
or/and ACC_MANDATED are allowed (see Opcodes ).Visits a parameter of this method. |
public AnnotationVisitor | Returns: a visitor to visit the annotation values, or null if this visitor is not interested in visiting this annotation.the parameter index. This index must be strictly smaller than the number of
parameters in the method descriptor, and strictly smaller than the parameter count
specified in parameter, final String visitAnnotableParameterCount .Important Note a parameter index i is not required to correspond to the i'th parameter descriptor in the method descriptor, in particular in case of synthetic parameters (see https://docs.oracle.com/javase/specs/jvms/se9/html/jvms-4.html#jvms-4.7.18). the class descriptor of the annotation class. descriptor, final boolean true if the annotation is visible at runtime. visible)Visits an annotation of a parameter this method. |
public void | visitTableSwitchInsn(final int
the minimum key value. min, final int the maximum key value. max, final Label beginning of the default handler block. dflt, final Label... beginnings of the handler blocks. labels)labels[i] is the beginning of the
handler block for the min + i key.Visits a TABLESWITCH instruction. |
public AnnotationVisitor | Returns: a visitor to visit the annotation values, or null if this visitor is not interested in visiting this annotation.a reference to the annotated type. The sort of this type reference must be
typeRef, final TypePath TypeReference#EXCEPTION_PARAMETER . See TypeReference .the path to the annotated type argument, wildcard bound, array element type, or
static inner type within 'typeRef'. May be null if the annotation targets
'typeRef' as a whole. typePath, final String the class descriptor of the annotation class. descriptor, final boolean true if the annotation is visible at runtime. visible)Visits an annotation on an exception handler type. |
public void | visitTryCatchBlock(final Label
the beginning of the exception handler's scope (inclusive). start, final Label the end of the exception handler's scope (exclusive). end, final Label the beginning of the exception handler's code. handler, final String the internal name of the type of exceptions handled by the handler (see type)Type#getInternalName() ), or null to catch any exceptions (for "finally"
blocks).Visits a try catch block. |
public AnnotationVisitor | Returns: a visitor to visit the annotation values, or null if this visitor is not interested in visiting this annotation.a reference to the annotated type. The sort of this type reference must be
typeRef, final TypePath TypeReference#METHOD_TYPE_PARAMETER , TypeReference#METHOD_TYPE_PARAMETER_BOUND , TypeReference#METHOD_RETURN , TypeReference#METHOD_RECEIVER , TypeReference#METHOD_FORMAL_PARAMETER or TypeReference#THROWS . See TypeReference .the path to the annotated type argument, wildcard bound, array element type, or
static inner type within 'typeRef'. May be null if the annotation targets
'typeRef' as a whole. typePath, final String the class descriptor of the annotation class. descriptor, final boolean true if the annotation is visible at runtime. visible)Visits an annotation on a type in the method signature. |
public void | visitTypeInsn(final int
the opcode of the type instruction to be visited. This opcode is either NEW,
ANEWARRAY, CHECKCAST or INSTANCEOF. opcode, final String the operand of the instruction to be visited. This operand must be the internal
name of an object or array class (see type)Type#getInternalName() ).Visits a type instruction. |
public void | visitVarInsn(final int
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. opcode, final int the operand of the instruction to be visited. This operand is the index of a
local variable. varIndex)Visits a local variable instruction. |
api | back to summary |
---|---|
protected final int api The ASM API version implemented by this visitor. The value of this field must be one of the
|
mv | back to summary |
---|---|
protected MethodVisitor mv The method visitor to which this visitor must delegate method calls. May be null. |
REQUIRES_ASM5 | back to summary |
---|---|
private static final String REQUIRES_ASM5 |
MethodVisitor | back to summary |
---|---|
protected MethodVisitor(final int api) Constructs a new
|
MethodVisitor | back to summary |
---|---|
protected MethodVisitor(final int api, final MethodVisitor methodVisitor) Constructs a new
|
getDelegate | back to summary |
---|---|
public MethodVisitor getDelegate() The method visitor to which this visitor must delegate method calls. May be null.
|
visitAnnotableParameterCount | back to summary |
---|---|
public void visitAnnotableParameterCount(final int parameterCount, final boolean visible) Visits the number of method parameters that can have annotations. By default (i.e. when this method is not called), all the method parameters defined by the method descriptor can have annotations.
|
visitAnnotation | back to summary |
---|---|
public AnnotationVisitor visitAnnotation(final String descriptor, final boolean visible) Visits an annotation of this method.
|
visitAnnotationDefault | back to summary |
---|---|
public AnnotationVisitor visitAnnotationDefault() Visits the default value of this annotation interface method.
|
visitAttribute | back to summary |
---|---|
public void visitAttribute(final Attribute attribute) Visits a non standard attribute of this method.
|
visitCode | back to summary |
---|---|
public void visitCode() Starts the visit of the method's code, if any (i.e. non abstract method). |
visitEnd | back to summary |
---|---|
public void visitEnd() Visits the end of the method. This method, which is the last one to be called, is used to inform the visitor that all the annotations and attributes of the method have been visited. |
visitFieldInsn | back to summary |
---|---|
public void visitFieldInsn(final int opcode, final String owner, final String name, final String descriptor) Visits a field instruction. A field instruction is an instruction that loads or stores the value of a field of an object.
|
visitFrame | back to summary |
---|---|
public void visitFrame(final int type, final int numLocal, final Object[] local, final int numStack, final Object[] stack) Visits the current state of the local variables and operand stack elements. This method must(*)
be called just before any instruction i that follows an unconditional branch
instruction such as GOTO or THROW, that is the target of a jump instruction, or that starts an
exception handler block. The visited types must describe the values of the local variables and
of the operand stack elements just before i is executed.
In both cases the first frame, corresponding to the method's parameters and access flags, is implicit and must not be visited. Also, it is illegal to visit two or more frames for the same code location (i.e., at least one instruction must be visited between two calls to visitFrame).
|
visitIincInsn | back to summary |
---|---|
public void visitIincInsn(final int varIndex, final int increment) Visits an IINC instruction.
|
visitInsn | back to summary |
---|---|
public void visitInsn(final int opcode) Visits a zero operand instruction.
|
visitInsnAnnotation | back to summary |
---|---|
public AnnotationVisitor visitInsnAnnotation(final int typeRef, final TypePath typePath, final String descriptor, final boolean visible) Visits an annotation on an instruction. This method must be called just after the annotated instruction. It can be called several times for the same instruction.
|
visitIntInsn | back to summary |
---|---|
public void visitIntInsn(final int opcode, final int operand) Visits an instruction with a single int operand.
|
visitInvokeDynamicInsn | back to summary |
---|---|
public void visitInvokeDynamicInsn(final String name, final String descriptor, final Handle bootstrapMethodHandle, final Object... bootstrapMethodArguments) Visits an invokedynamic instruction.
|
visitJumpInsn | back to summary |
---|---|
public void visitJumpInsn(final int opcode, final Label label) Visits a jump instruction. A jump instruction is an instruction that may jump to another instruction.
|
visitLabel | back to summary |
---|---|
public void visitLabel(final Label label) Visits a label. A label designates the instruction that will be visited just after it. |
visitLdcInsn | back to summary |
---|---|
public void visitLdcInsn(final Object value) Visits a LDC instruction. Note that new constant types may be added in future versions of the Java Virtual Machine. To easily detect new constant types, implementations of this method should check for unexpected constant types, like this: if (cst instanceof Integer) { // ... } else if (cst instanceof Float) { // ... } else if (cst instanceof Long) { // ... } else if (cst instanceof Double) { // ... } else if (cst instanceof String) { // ... } else if (cst instanceof Type) { int sort = ((Type) cst).getSort(); if (sort == Type.OBJECT) { // ... } else if (sort == Type.ARRAY) { // ... } else if (sort == Type.METHOD) { // ... } else { // throw an exception } } else if (cst instanceof Handle) { // ... } else if (cst instanceof ConstantDynamic) { // ... } else { // throw an exception }
|
visitLineNumber | back to summary |
---|---|
public void visitLineNumber(final int line, final Label start) Visits a line number declaration.
|
visitLocalVariable | back to summary |
---|---|
public void visitLocalVariable(final String name, final String descriptor, final String signature, final Label start, final Label end, final int index) Visits a local variable declaration.
|
visitLocalVariableAnnotation | back to summary |
---|---|
public AnnotationVisitor visitLocalVariableAnnotation(final int typeRef, final TypePath typePath, final Label[] start, final Label[] end, final int[] index, final String descriptor, final boolean visible) Visits an annotation on a local variable type.
|
visitLookupSwitchInsn | back to summary |
---|---|
public void visitLookupSwitchInsn(final Label dflt, final int[] keys, final Label[] labels) Visits a LOOKUPSWITCH instruction. |
visitMaxs | back to summary |
---|---|
public void visitMaxs(final int maxStack, final int maxLocals) Visits the maximum stack size and the maximum number of local variables of the method.
|
visitMethodInsn | back to summary |
---|---|
public void visitMethodInsn(final int opcode, final String owner, final String name, final String descriptor)
Deprecated use Visits a method instruction. A method instruction is an instruction that invokes a method.
|
visitMethodInsn | back to summary |
---|---|
public void visitMethodInsn(final int opcode, final String owner, final String name, final String descriptor, final boolean isInterface) Visits a method instruction. A method instruction is an instruction that invokes a method.
|
visitMultiANewArrayInsn | back to summary |
---|---|
public void visitMultiANewArrayInsn(final String descriptor, final int numDimensions) Visits a MULTIANEWARRAY instruction. |
visitParameter | back to summary |
---|---|
public void visitParameter(final String name, final int access) Visits a parameter of this method. |
visitParameterAnnotation | back to summary |
---|---|
public AnnotationVisitor visitParameterAnnotation(final int parameter, final String descriptor, final boolean visible) Visits an annotation of a parameter this method.
|
visitTableSwitchInsn | back to summary |
---|---|
public void visitTableSwitchInsn(final int min, final int max, final Label dflt, final Label... labels) Visits a TABLESWITCH instruction. |
visitTryCatchAnnotation | back to summary |
---|---|
public AnnotationVisitor visitTryCatchAnnotation(final int typeRef, final TypePath typePath, final String descriptor, final boolean visible) Visits an annotation on an exception handler type. This method must be called after the
|
visitTryCatchBlock | back to summary |
---|---|
public void visitTryCatchBlock(final Label start, final Label end, final Label handler, final String type) Visits a try catch block.
|
visitTypeAnnotation | back to summary |
---|---|
public AnnotationVisitor visitTypeAnnotation(final int typeRef, final TypePath typePath, final String descriptor, final boolean visible) Visits an annotation on a type in the method signature.
|
visitTypeInsn | back to summary |
---|---|
public void visitTypeInsn(final int opcode, final String type) Visits a type instruction. A type instruction is an instruction that takes the internal name of
a class as parameter (see
|
visitVarInsn | back to summary |
---|---|
public void visitVarInsn(final int opcode, final int varIndex) Visits a local variable instruction. A local variable instruction is an instruction that loads or stores the value of a local variable.
|