Class AnnotationWriter
java.lang.Object
com.googlecode.aviator.asm.AnnotationVisitor
com.googlecode.aviator.asm.AnnotationWriter
An
AnnotationVisitor that generates annotations in bytecode form.-
Field Summary
FieldsModifier and TypeFieldDescriptionprivate final ByteVectorThe annotation values in bytecode form.private final ClassWriterThe class writer to which this annotation must be added.private final booleantrue if values are named, false otherwise.(package private) AnnotationWriterNext annotation writer.private final intWhere the number of values of this annotation must be stored inparent.private final ByteVectorThe byte vector to be used to store the number of values of this annotation.(package private) AnnotationWriterPrevious annotation writer.private intThe number of values in this annotation.Fields inherited from class AnnotationVisitor
api, av -
Constructor Summary
ConstructorsConstructorDescriptionAnnotationWriter(ClassWriter cw, boolean named, ByteVector bv, ByteVector parent, int offset) Constructs a newAnnotationWriter. -
Method Summary
Modifier and TypeMethodDescription(package private) intgetSize()Returns the size of this annotation writer list.(package private) static voidput(AnnotationWriter[] panns, int off, ByteVector out) Puts the given annotation lists into the given byte vector.(package private) voidput(ByteVector out) Puts the annotations of this annotation writer list into the given byte vector.voidVisits 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.
-
Field Details
-
cw
The class writer to which this annotation must be added. -
size
private int sizeThe number of values in this annotation. -
named
private final boolean namedtrue if values are named, false otherwise. Annotation writers used for annotation default and annotation arrays use unnamed values. -
bv
The annotation values in bytecode form. This byte vector only contains the values themselves, i.e. the number of values must be stored as a unsigned short just before these bytes. -
parent
The byte vector to be used to store the number of values of this annotation. Seebv. -
offset
private final int offsetWhere the number of values of this annotation must be stored inparent. -
next
AnnotationWriter nextNext annotation writer. This field is used to store annotation lists. -
prev
AnnotationWriter prevPrevious annotation writer. This field is used to store annotation lists.
-
-
Constructor Details
-
AnnotationWriter
AnnotationWriter(ClassWriter cw, boolean named, ByteVector bv, ByteVector parent, int offset) Constructs a newAnnotationWriter.- Parameters:
cw- the class writer to which this annotation must be added.named- true if values are named, false otherwise.bv- where the annotation values must be stored.parent- where the number of annotation values must be stored.offset- where in parent the number of annotation values must be stored.
-
-
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,StringorTypeor OBJECT or ARRAY sort. 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
Description copied from class:AnnotationVisitorVisits an enumeration value of the annotation.- Overrides:
visitEnumin classAnnotationVisitor- Parameters:
name- the value name.desc- 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.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
Description copied from class:AnnotationVisitorVisits 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.- 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
-
getSize
int getSize()Returns the size of this annotation writer list.- Returns:
- the size of this annotation writer list.
-
put
Puts the annotations of this annotation writer list into the given byte vector.- Parameters:
out- where the annotations must be put.
-
put
Puts the given annotation lists into the given byte vector.- Parameters:
panns- an array of annotation writer lists.off- index of the first annotation to be written.out- where the annotations must be put.
-