Package org.springframework.asm
Class AnnotationVisitor
java.lang.Object
org.springframework.asm.AnnotationVisitor
- Direct Known Subclasses:
AnnotationVisitorTee
A visitor to visit a Java annotation. The methods of this class must be called in the following
order: (
visit
| visitEnum
| visitAnnotation
| visitArray
)*
visitEnd
.- Author:
- Eric Bruneton, Eugene Kuleshov
-
Field Summary
Modifier and TypeFieldDescriptionprotected final int
The ASM API version implemented by this visitor.protected AnnotationVisitor
The annotation visitor to which this visitor must delegate method calls. -
Constructor Summary
ModifierConstructorDescriptionprotected
AnnotationVisitor
(int api) Constructs a newAnnotationVisitor
.protected
AnnotationVisitor
(int api, AnnotationVisitor annotationVisitor) Constructs a newAnnotationVisitor
. -
Method Summary
Modifier and TypeMethodDescriptionThe annotation visitor to which this visitor must delegate method calls.void
Visits a primitive value of the annotation.visitAnnotation
(String name, String descriptor) Visits a nested annotation value of the annotation.visitArray
(String name) Visits an array value of the annotation.void
visitEnd()
Visits the end of the annotation.void
Visits an enumeration value of the annotation.
-
Field Details
-
api
protected final int apiThe ASM API version implemented by this visitor. The value of this field must be one of theASM
x values inOpcodes
. -
av
The annotation visitor to which this visitor must delegate method calls. May be null.
-
-
Constructor Details
-
AnnotationVisitor
protected AnnotationVisitor(int api) Constructs a newAnnotationVisitor
.- Parameters:
api
- the ASM API version implemented by this visitor. Must be one of theASM
x values inOpcodes
.
-
AnnotationVisitor
Constructs a newAnnotationVisitor
.- Parameters:
api
- the ASM API version implemented by this visitor. Must be one of theASM
x values inOpcodes
.annotationVisitor
- the annotation visitor to which this visitor must delegate method calls. May be null.
-
-
Method Details
-
getDelegate
The annotation visitor to which this visitor must delegate method calls. May be null.- Returns:
- the annotation visitor to which this visitor must delegate method calls, or null.
-
visit
Visits a primitive value of the annotation.- Parameters:
name
- the value name.value
- the actual value, whose type must beByte
,Boolean
,Character
,Short
,Integer
,Long
,Float
,Double
,String
orType
ofType.OBJECT
orType.ARRAY
sort. This value can also be an array of byte, boolean, short, char, int, long, float or double values (this is equivalent to usingvisitArray(java.lang.String)
and visiting each array element in turn, but is more convenient).
-
visitEnum
Visits an enumeration value of the annotation.- Parameters:
name
- the value name.descriptor
- the class descriptor of the enumeration class.value
- the actual enumeration value.
-
visitAnnotation
Visits a nested annotation value of the annotation.- Parameters:
name
- the value name.descriptor
- the class descriptor of the nested annotation class.- Returns:
- a visitor to visit the actual nested annotation value, or null if this visitor is not interested in visiting this nested annotation. The nested annotation value must be fully visited before calling other methods on this annotation visitor.
-
visitArray
Visits an array value of the annotation. Note that arrays of primitive values (such as byte, boolean, short, char, int, long, float or double) can be passed as value tovisit
. This is whatClassReader
does for non empty arrays of primitive values.- Parameters:
name
- the value name.- Returns:
- a visitor to visit the actual array value elements, or null if this visitor is not interested in visiting these values. The 'name' parameters passed to the methods of this visitor are ignored. All the array values must be visited before calling other methods on this annotation visitor.
-
visitEnd
public void visitEnd()Visits the end of the annotation.
-