Interface AnnotationVisitor
- All Known Implementing Classes:
AnnotationNode, ASMifierAnnotationVisitor, CheckAnnotationAdapter, EmptyVisitor, RemappingAnnotationAdapter, SAXAnnotationAdapter, TraceAnnotationVisitor
public interface AnnotationVisitor
A visitor to visit a Java annotation. The methods of this interface must be
called in the following order: (visit | visitEnum |
visitAnnotation | visitArray)* visitEnd.
- Author:
- Eric Bruneton, Eugene Kuleshov
-
Method Summary
Modifier and TypeMethodDescriptionvoidVisits a primitive value of the annotation.visitAnnotation(String name, String desc) Visits a nested annotation value of the annotation.visitArray(String name) Visits an array value of the annotation.voidvisitEnd()Visits the end of the annotation.voidVisits an enumeration value of the annotation.
-
Method Details
-
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,StringorType. This value can also be an array of byte, boolean, short, char, int, long, float or double values (this is equivalent to usingvisitArrayand visiting each array element in turn, but is more convenient).
-
visitEnum
-
visitAnnotation
Visits a nested annotation value of the annotation.- Parameters:
name- the value name.desc- 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 types (such as byte, boolean, short, char, int, long, float or double) can be passed as value tovisit. This is whatClassReaderdoes.- 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
void visitEnd()Visits the end of the annotation.
-