Class AnnotationFileParser

java.lang.Object
org.checkerframework.framework.stub.AnnotationFileParser

public class AnnotationFileParser extends Object
This class has three static methods. Each method parses an annotation file and adds annotations to the AnnotationFileParser.AnnotationFileAnnotations passed as an argument.

The first main entry point is parseStubFile(String, InputStream, AnnotatedTypeFactory, ProcessingEnvironment, AnnotationFileAnnotations, AnnotationFileUtil.AnnotationFileType), which side-effects its last argument. It operates in two steps. First, it calls the Annotation File Parser to parse an annotation file. Then, it walks the AST to create/collect types and declaration annotations.

The second main entry point is parseAjavaFile(String, InputStream, CompilationUnitTree, AnnotatedTypeFactory, ProcessingEnvironment, AnnotationFileAnnotations). This behaves the same as parseStubFile(String, InputStream, AnnotatedTypeFactory, ProcessingEnvironment, AnnotationFileAnnotations, AnnotationFileUtil.AnnotationFileType), but takes an ajava file instead.

The other entry point is parseJdkFileAsStub(java.lang.String, java.io.InputStream, org.checkerframework.framework.type.AnnotatedTypeFactory, javax.annotation.processing.ProcessingEnvironment, org.checkerframework.framework.stub.AnnotationFileParser.AnnotationFileAnnotations).

  • Method Details

    • annosInPackage

      public static Map<String,TypeElement> annosInPackage(PackageElement packageElement)
      All annotations defined in the package (but not those nested within classes in the package). Keys are both fully-qualified and simple names.
      Parameters:
      packageElement - a package
      Returns:
      a map from annotation name to TypeElement
    • annosInType

      public static Map<String,TypeElement> annosInType(TypeElement typeElement)
      All annotations declared (directly) within a class. Keys are both fully-qualified and simple names.
      Parameters:
      typeElement - a type
      Returns:
      a map from annotation name to TypeElement
    • createNameToAnnotationMap

      public static Map<String,TypeElement> createNameToAnnotationMap(List<TypeElement> typeElements)
      All annotations declared within any of the given elements.
      Parameters:
      typeElements - the elements whose annotations to retrieve
      Returns:
      a map from annotation names (both fully-qualified and simple names) to TypeElement
    • parseStubFile

      public static void parseStubFile(String filename, InputStream inputStream, AnnotatedTypeFactory atypeFactory, ProcessingEnvironment processingEnv, AnnotationFileParser.AnnotationFileAnnotations annotationFileAnnos, AnnotationFileUtil.AnnotationFileType fileType)
      The main entry point. Parse a stub file and side-effects the annotationFileAnnos argument.
      Parameters:
      filename - name of stub file, used only for diagnostic messages
      inputStream - of stub file to parse
      atypeFactory - the type factory
      processingEnv - the processing environment
      annotationFileAnnos - annotations from the annotation file; side-effected by this method
      fileType - the annotation file type and source
    • parseAjavaFile

      public static void parseAjavaFile(String filename, InputStream inputStream, CompilationUnitTree root, AnnotatedTypeFactory atypeFactory, ProcessingEnvironment processingEnv, AnnotationFileParser.AnnotationFileAnnotations ajavaAnnos)
      The main entry point when parsing an ajava file. Parses an ajava file and side-effects the last two arguments.
      Parameters:
      filename - name of ajava file, used only for diagnostic messages
      inputStream - of ajava file to parse
      root - javac tree for the file to be parsed
      atypeFactory - the type factory
      processingEnv - the processing environment
      ajavaAnnos - annotations from the ajava file; side-effected by this method
    • parseJdkFileAsStub

      public static void parseJdkFileAsStub(String filename, InputStream inputStream, AnnotatedTypeFactory atypeFactory, ProcessingEnvironment processingEnv, AnnotationFileParser.AnnotationFileAnnotations stubAnnos)
      Parse a stub file that is a part of the annotated JDK and side-effects the stubAnnos argument.
      Parameters:
      filename - name of stub file, used only for diagnostic messages
      inputStream - of stub file to parse
      atypeFactory - the type factory
      processingEnv - the processing environment
      stubAnnos - annotations from the stub file; side-effected by this method
    • putIfAbsent

      public static <K, V> void putIfAbsent(Map<K,V> m, K key, V value)
      Just like Map.put, but does not override any existing value in the map.
      Type Parameters:
      K - the key type
      V - the value type
      Parameters:
      m - a map
      key - a key
      value - the value to associate with the key, if the key isn't already in the map
    • putAllNew

      public static <K, V> void putAllNew(Map<K,V> m, Map<K,V> m2)
      Just like Map.putAll, but modifies existing values using putIfAbsent(Map, Object, Object).
      Type Parameters:
      K - the key type for the maps
      V - the value type for the maps
      Parameters:
      m - the destination map
      m2 - the source map