public class VariableApplier extends Object
| Modifier and Type | Field and Description | 
|---|---|
| protected Element | elementAn Element that type represents. | 
| protected AnnotatedTypeMirror | typeThe type to which we wish to apply annotations. | 
| Modifier and Type | Method and Description | 
|---|---|
| static boolean | accepts(AnnotatedTypeMirror typeMirror,
       Element element)Returns true if this is a variable declaration including fields an enum constants. | 
| protected com.sun.tools.javac.code.TargetType[] | annotatedTargets()Returns the TargetTypes that identify annotations we wish to apply with this object. | 
| static void | apply(AnnotatedTypeMirror type,
     Element element)Apply annotations from  elementtotype. | 
| void | extractAndApply()Reads the list of annotations that apply to this element (see getRawTypeAttributes). | 
| protected Iterable<com.sun.tools.javac.code.Attribute.TypeCompound> | getRawTypeAttributes()Annotations on elements are represented as Attribute.TypeCompounds ( a subtype of
 AnnotationMirror) that are usually accessed through a getRawTypeAttributes method on the
 element. | 
| protected void | handleInvalid(List<com.sun.tools.javac.code.Attribute.TypeCompound> invalid)This implementation reports all invalid annotations as errors. | 
| protected void | handleTargeted(List<com.sun.tools.javac.code.Attribute.TypeCompound> targeted)This method should apply all annotations that are handled by this object. | 
| protected void | handleValid(List<com.sun.tools.javac.code.Attribute.TypeCompound> valid)The default implementation of this method does nothing. | 
| protected boolean | isAccepted()Tests element/type fields to ensure that this TargetedElementAnnotationApplier is valid for
 this element/type pair. | 
| protected Map<org.checkerframework.framework.util.element.TargetedElementAnnotationApplier.TargetClass,List<com.sun.tools.javac.code.Attribute.TypeCompound>> | sift(Iterable<com.sun.tools.javac.code.Attribute.TypeCompound> typeCompounds)Separate the input annotations into a Map of TargetClass (TARGETED, VALID, INVALID) to the
 annotations that fall into each of those categories. | 
| protected com.sun.tools.javac.code.TargetType[] | validTargets()Returns the TargetTypes that identify annotations that are valid but we wish to ignore. | 
protected final AnnotatedTypeMirror type
protected final Element element
public static void apply(AnnotatedTypeMirror type, Element element) throws ElementAnnotationUtil.UnexpectedAnnotationLocationException
element to type.public static boolean accepts(AnnotatedTypeMirror typeMirror, Element element)
typeMirror - ignoredprotected com.sun.tools.javac.code.TargetType[] annotatedTargets()
protected com.sun.tools.javac.code.TargetType[] validTargets()
protected Iterable<com.sun.tools.javac.code.Attribute.TypeCompound> getRawTypeAttributes()
In Java 8 and later these annotations are generally contained by elements to which they apply. However, in earlier versions of Java many of these annotations are handled by either the enclosing method, e.g. parameters and method type parameters, or enclosing class, e.g. class type parameters. Therefore, many annotations are addressed by first getting all annotations on a method or class and the picking out only the ones we wish to target (see extractAndApply).
protected boolean isAccepted()
protected void handleTargeted(List<com.sun.tools.javac.code.Attribute.TypeCompound> targeted) throws ElementAnnotationUtil.UnexpectedAnnotationLocationException
targeted - the list of annotations that were returned by getRawTypeAttributes and had a
     TargetType contained by annotatedTargetsElementAnnotationUtil.UnexpectedAnnotationLocationExceptionpublic void extractAndApply()
                     throws ElementAnnotationUtil.UnexpectedAnnotationLocationException
This method will throw a runtime exception if isAccepted returns false.
protected void handleValid(List<com.sun.tools.javac.code.Attribute.TypeCompound> valid)
valid - the list of annotations that were returned by getRawTypeAttributes and had a
     TargetType contained by valid and NOT annotatedTargetsprotected void handleInvalid(List<com.sun.tools.javac.code.Attribute.TypeCompound> invalid)
invalid - the list of annotations that were returned by getRawTypeAttributes and were not
     handled by handleTargeted or handleValidprotected Map<org.checkerframework.framework.util.element.TargetedElementAnnotationApplier.TargetClass,List<com.sun.tools.javac.code.Attribute.TypeCompound>> sift(Iterable<com.sun.tools.javac.code.Attribute.TypeCompound> typeCompounds)
typeCompounds - annotations to sift through, should be those returned by
     getRawTypeAttributes