Module org.eclipse.persistence.asm
Class AnnotationNode
java.lang.Object
org.eclipse.persistence.internal.libraries.asm.AnnotationVisitor
org.eclipse.persistence.internal.libraries.asm.tree.AnnotationNode
- Direct Known Subclasses:
TypeAnnotationNode
A node that represents an annotation.
-
Field Summary
FieldsModifier and TypeFieldDescriptionThe class descriptor of the annotation class.The name value pairs of this annotation.Fields inherited from class org.eclipse.persistence.internal.libraries.asm.AnnotationVisitor
api, av -
Constructor Summary
ConstructorsConstructorDescriptionAnnotationNode(int api, String descriptor) Constructs a newAnnotationNode.AnnotationNode(String descriptor) Constructs a newAnnotationNode. -
Method Summary
Modifier and TypeMethodDescriptionvoidaccept(AnnotationVisitor annotationVisitor) Makes the given visitor visit this annotation.voidcheck(int api) Checks that this annotation node is compatible with the given ASM API version.voidVisits 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.voidvisitEnd()Visits the end of the annotation.voidVisits an enumeration value of the annotation.Methods inherited from class org.eclipse.persistence.internal.libraries.asm.AnnotationVisitor
getDelegate
-
Field Details
-
desc
The class descriptor of the annotation class. -
values
The name value pairs of this annotation. Each name value pair is stored as two consecutive elements in the list. The name is aString, and the value may be aByte,Boolean,Character,Short,Integer,Long,Float,Double,StringorType, or a two elements String array (for enumeration values), anAnnotationNode, or aListof values of one of the preceding types. The list may be null if there is no name value pair.
-
-
Constructor Details
-
AnnotationNode
Constructs a newAnnotationNode. Subclasses must not use this constructor. Instead, they must use theAnnotationNode(int, String)version.- Parameters:
descriptor- the class descriptor of the annotation class.- Throws:
IllegalStateException- If a subclass calls this constructor.
-
AnnotationNode
Constructs a newAnnotationNode.- Parameters:
api- the ASM API version implemented by this visitor. Must be one of theASMx values inOpcodes.descriptor- the class descriptor of the annotation class.
-
-
Method Details
-
visit
Description copied from class:AnnotationVisitorVisits a primitive value of the annotation.- Overrides:
visitin classAnnotationVisitor- Parameters:
name- the value name.value- the actual value, whose type must beByte,Boolean,Character,Short,Integer,Long,Float,Double,StringorTypeofType.OBJECTorType.ARRAYsort. This value can also be an array of byte, boolean, short, char, int, long, float or double values (this is equivalent to usingAnnotationVisitor.visitArray(java.lang.String)and visiting each array element in turn, but is more convenient).
-
visitEnum
Description copied from class:AnnotationVisitorVisits an enumeration value of the annotation.- Overrides:
visitEnumin classAnnotationVisitor- Parameters:
name- the value name.descriptor- the class descriptor of the enumeration class.value- the actual enumeration value.
-
visitAnnotation
Description copied from class:AnnotationVisitorVisits a nested annotation value of the annotation.- Overrides:
visitAnnotationin classAnnotationVisitor- 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
Description copied from class:AnnotationVisitorVisits 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 whatClassReaderdoes for non empty arrays of primitive values.- Overrides:
visitArrayin classAnnotationVisitor- 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()Description copied from class:AnnotationVisitorVisits the end of the annotation.- Overrides:
visitEndin classAnnotationVisitor
-
check
public void check(int api) Checks that this annotation node is compatible with the given ASM API version. This method checks that this node, and all its children recursively, do not contain elements that were introduced in more recent versions of the ASM API than the given version.- Parameters:
api- an ASM API version. Must be one of theASMx values inOpcodes.
-
accept
Makes the given visitor visit this annotation.- Parameters:
annotationVisitor- an annotation visitor. Maybe null.
-