Class WholeProgramInferenceScenesStorage
- All Implemented Interfaces:
WholeProgramInferenceStorage<org.checkerframework.afu.scenelib.el.ATypeElement>
The set of annotations inferred for a certain class is stored in an AScene
, which
writeScenes()
can write into a file. For example, a class my.pakkage.MyClass
will
have its members' inferred types stored in a Scene, and later written into a file named
my.pakkage.MyClass.jaif
if using WholeProgramInference.OutputFormat.JAIF
, or my.pakkage.MyClass.astub
if using WholeProgramInference.OutputFormat.STUB
.
This class populates the initial Scenes by reading existing .jaif files on the JAIF_FILES_PATH
directory (regardless of output format). Having more information in those
initial .jaif files means that the precision achieved by the whole-program inference analysis
will be better. writeScenes(org.checkerframework.common.wholeprograminference.WholeProgramInference.OutputFormat, org.checkerframework.common.basetype.BaseTypeChecker)
rewrites the initial .jaif files and may create new ones.
-
Nested Class Summary
Modifier and TypeClassDescriptionstatic class
Maps theaTypeElementToString(org.checkerframework.afu.scenelib.el.ATypeElement)
representation of an ATypeElement and its TypeUseLocation to a set of names of annotations. -
Field Summary
Modifier and TypeFieldDescriptionprotected final AnnotatedTypeFactory
The type factory associated with this WholeProgramInferenceScenesStorage.static final String
Directory where .jaif files will be written to and read from.Scenes that were modified since the last time all Scenes were written into .jaif files.final Map<String,
ASceneWrapper> Maps .jaif file paths (Strings) to Scenes. -
Constructor Summary
ConstructorDescriptionWholeProgramInferenceScenesStorage
(AnnotatedTypeFactory atypeFactory) Default constructor. -
Method Summary
Modifier and TypeMethodDescriptionboolean
addClassDeclarationAnnotation
(TypeElement classElt, AnnotationMirror anno) Adds an annotation to a class declaration.boolean
addDeclarationAnnotationToFormalParameter
(ExecutableElement methodElt, int index, AnnotationMirror anno) Adds a declaration annotation to a formal parameter.boolean
addFieldDeclarationAnnotation
(VariableElement field, AnnotationMirror anno) Updates a field to add a declaration annotation.boolean
addMethodDeclarationAnnotation
(ExecutableElement methodElt, AnnotationMirror anno) Updates a method to add a declaration annotation.atmFromStorageLocation
(TypeMirror typeMirror, org.checkerframework.afu.scenelib.el.ATypeElement storageLocation) Obtain the type from a storage location.static String
aTypeElementToString
(org.checkerframework.afu.scenelib.el.ATypeElement aType) Returns a string representation of an ATypeElement, for use as part of a key inWholeProgramInferenceScenesStorage.AnnotationsInContexts
.protected org.checkerframework.afu.scenelib.el.AClass
getAClass
(@BinaryName String className, String jaifPath) Returns the scene-lib representation of the given className in the scene identified by the given jaifPath.protected org.checkerframework.afu.scenelib.el.AClass
getAClass
(@BinaryName String className, String jaifPath, @Nullable com.sun.tools.javac.code.Symbol.ClassSymbol classSymbol) Returns the scene-lib representation of the given className in the scene identified by the given jaifPath.org.checkerframework.afu.scenelib.el.ATypeElement
getFieldAnnotations
(Element element, String fieldName, AnnotatedTypeMirror lhsATM, AnnotatedTypeFactory atypeFactory) Get the annotations for a field type.getFileForElement
(Element elt) Returns the file corresponding to the given element.protected String
getJaifPath
(String className) Returns the String representing the .jaif path of a class given its name.org.checkerframework.afu.scenelib.el.ATypeElement
getParameterAnnotations
(ExecutableElement methodElt, int i, AnnotatedTypeMirror paramATM, VariableElement ve, AnnotatedTypeFactory atypeFactory) Get the annotations for a formal parameter type.getPostconditionDeclaredType
(org.checkerframework.afu.scenelib.el.AMethod m, String expression) Fetches the declared type of an expression for which a postcondition was inferred, for the given AMethod.getPreconditionDeclaredType
(org.checkerframework.afu.scenelib.el.AMethod m, String expression) Fetches the declared type of an expression for which a precondition was inferred, for the given AMethod.org.checkerframework.afu.scenelib.el.ATypeElement
getPreOrPostconditions
(Analysis.BeforeOrAfter preOrPost, ExecutableElement methodElement, String expression, AnnotatedTypeMirror declaredType, AnnotatedTypeFactory atypeFactory) Returns the pre- or postcondition annotations for an expression.org.checkerframework.afu.scenelib.el.ATypeElement
getReceiverAnnotations
(ExecutableElement methodElt, AnnotatedTypeMirror paramATM, AnnotatedTypeFactory atypeFactory) Get the annotations for the receiver type.org.checkerframework.afu.scenelib.el.ATypeElement
getReturnAnnotations
(ExecutableElement methodElt, AnnotatedTypeMirror atm, AnnotatedTypeFactory atypeFactory) Get the annotations for the return type.boolean
hasStorageLocationForMethod
(ExecutableElement methodElt) Given an ExecutableElement in a compilation unit that has already been read into storage, returns whether there exists a stored method matchingelt
.void
prepareClassForWriting
(org.checkerframework.afu.scenelib.el.AClass classAnnos) Side-effects the class annotations to make any desired changes before writing to a file.void
prepareMethodForWriting
(org.checkerframework.afu.scenelib.el.AMethod methodAnnos) Side-effects the method or constructor annotations to make any desired changes before writing to a file.void
prepareSceneForWriting
(org.checkerframework.afu.scenelib.el.AScene compilationUnitAnnos) Side-effects the compilation unit annotations to make any desired changes before writing to a file.void
preprocessClassTree
(ClassTree classTree) Performs any preparation required for inference on the elements of a class.void
setFileModified
(String path) Indicates that inferred annotations for the file atpath
have changed since last written.protected void
updateAnnotationSetInScene
(org.checkerframework.afu.scenelib.el.ATypeElement type, TypeUseLocation defLoc, AnnotatedTypeMirror rhsATM, AnnotatedTypeMirror lhsATM, String jaifPath, boolean ignoreIfAnnotated) Updates the set of annotations in a location of a Scene, as the result of a pseudo-assignment.void
updateStorageLocationFromAtm
(AnnotatedTypeMirror newATM, AnnotatedTypeMirror curATM, org.checkerframework.afu.scenelib.el.ATypeElement typeToUpdate, TypeUseLocation defLoc, boolean ignoreIfAnnotated) Updates a storage location to have the annotations of the givenAnnotatedTypeMirror
.void
writeResultsToFile
(WholeProgramInference.OutputFormat outputFormat, BaseTypeChecker checker) Writes the inferred results to a file.void
writeScenes
(WholeProgramInference.OutputFormat outputFormat, BaseTypeChecker checker) Write all modified scenes into files.
-
Field Details
-
JAIF_FILES_PATH
Directory where .jaif files will be written to and read from. This directory is relative to where the CF's javac command is executed. -
atypeFactory
The type factory associated with this WholeProgramInferenceScenesStorage. -
scenes
Maps .jaif file paths (Strings) to Scenes. Relative to JAIF_FILES_PATH. -
modifiedScenes
Scenes that were modified since the last time all Scenes were written into .jaif files. Each String element of this set is a path (relative to JAIF_FILES_PATH) to the .jaif file of the corresponding Scene in the set. It is obtained by passing a class name as argument to thegetJaifPath(java.lang.String)
method.Modifying a Scene means adding (or changing) a type annotation for a field, method return type, or method parameter type in the Scene. (Scenes are modified by the method
updateAnnotationSetInScene(org.checkerframework.afu.scenelib.el.ATypeElement, org.checkerframework.framework.qual.TypeUseLocation, org.checkerframework.framework.type.AnnotatedTypeMirror, org.checkerframework.framework.type.AnnotatedTypeMirror, java.lang.String, boolean)
.)
-
-
Constructor Details
-
WholeProgramInferenceScenesStorage
Default constructor.- Parameters:
atypeFactory
- the type factory associated with this WholeProgramInferenceScenesStorage
-
-
Method Details
-
getFileForElement
Description copied from interface:WholeProgramInferenceStorage
Returns the file corresponding to the given element. This may side-effect the storage to load the file if it hasn't been read yet.- Specified by:
getFileForElement
in interfaceWholeProgramInferenceStorage<org.checkerframework.afu.scenelib.el.ATypeElement>
- Parameters:
elt
- an element- Returns:
- the path to the file where inference results for the element will be written
-
hasStorageLocationForMethod
Description copied from interface:WholeProgramInferenceStorage
Given an ExecutableElement in a compilation unit that has already been read into storage, returns whether there exists a stored method matchingelt
.An implementation is permitted to return false if
elt
represents a method that was synthetically added by javac, such as zero-argument constructors or valueOf(String) methods for enum types.- Specified by:
hasStorageLocationForMethod
in interfaceWholeProgramInferenceStorage<org.checkerframework.afu.scenelib.el.ATypeElement>
- Parameters:
methodElt
- a method or constructor Element- Returns:
- true if the storage has a method corresponding to
elt
-
getParameterAnnotations
public org.checkerframework.afu.scenelib.el.ATypeElement getParameterAnnotations(ExecutableElement methodElt, int i, AnnotatedTypeMirror paramATM, VariableElement ve, AnnotatedTypeFactory atypeFactory) Description copied from interface:WholeProgramInferenceStorage
Get the annotations for a formal parameter type.- Specified by:
getParameterAnnotations
in interfaceWholeProgramInferenceStorage<org.checkerframework.afu.scenelib.el.ATypeElement>
- Parameters:
methodElt
- the method or constructor Elementi
- the parameter index (0-based)paramATM
- the parameter typeve
- the parameter variableatypeFactory
- the type factory- Returns:
- the annotations for a formal parameter type
-
getReceiverAnnotations
public org.checkerframework.afu.scenelib.el.ATypeElement getReceiverAnnotations(ExecutableElement methodElt, AnnotatedTypeMirror paramATM, AnnotatedTypeFactory atypeFactory) Description copied from interface:WholeProgramInferenceStorage
Get the annotations for the receiver type.- Specified by:
getReceiverAnnotations
in interfaceWholeProgramInferenceStorage<org.checkerframework.afu.scenelib.el.ATypeElement>
- Parameters:
methodElt
- the method or constructor ElementparamATM
- the receiver typeatypeFactory
- the type factory- Returns:
- the annotations for the receiver type
-
getReturnAnnotations
public org.checkerframework.afu.scenelib.el.ATypeElement getReturnAnnotations(ExecutableElement methodElt, AnnotatedTypeMirror atm, AnnotatedTypeFactory atypeFactory) Description copied from interface:WholeProgramInferenceStorage
Get the annotations for the return type.- Specified by:
getReturnAnnotations
in interfaceWholeProgramInferenceStorage<org.checkerframework.afu.scenelib.el.ATypeElement>
- Parameters:
methodElt
- the method or constructor Elementatm
- the return typeatypeFactory
- the type factory- Returns:
- the annotations for the return type
-
getFieldAnnotations
public org.checkerframework.afu.scenelib.el.ATypeElement getFieldAnnotations(Element element, String fieldName, AnnotatedTypeMirror lhsATM, AnnotatedTypeFactory atypeFactory) Description copied from interface:WholeProgramInferenceStorage
Get the annotations for a field type.- Specified by:
getFieldAnnotations
in interfaceWholeProgramInferenceStorage<org.checkerframework.afu.scenelib.el.ATypeElement>
- Parameters:
element
- the element for the fieldfieldName
- the simple field namelhsATM
- the field typeatypeFactory
- the annotated type factory- Returns:
- the annotations for a field type
-
getPreOrPostconditions
public org.checkerframework.afu.scenelib.el.ATypeElement getPreOrPostconditions(Analysis.BeforeOrAfter preOrPost, ExecutableElement methodElement, String expression, AnnotatedTypeMirror declaredType, AnnotatedTypeFactory atypeFactory) Description copied from interface:WholeProgramInferenceStorage
Returns the pre- or postcondition annotations for an expression. The format of the expression is the same as a programmer would write in aRequiresQualifier
orEnsuresQualifier
annotation.This method may return null if the given expression is not a supported expression type. Currently, the supported expression types are: fields of "this" (e.g. "this.f", pre- and postconditions), "this" (postconditions only), and method parameters (e.g. "#1", "#2", postconditions only).
- Specified by:
getPreOrPostconditions
in interfaceWholeProgramInferenceStorage<org.checkerframework.afu.scenelib.el.ATypeElement>
- Parameters:
preOrPost
- whether to get the precondition or postconditionmethodElement
- the methodexpression
- the expressiondeclaredType
- the declared type of the expressionatypeFactory
- the type factory- Returns:
- the pre- or postcondition annotations for an expression, or null if the given expression is not a supported expression type
-
getPreconditionDeclaredType
public AnnotatedTypeMirror getPreconditionDeclaredType(org.checkerframework.afu.scenelib.el.AMethod m, String expression) Fetches the declared type of an expression for which a precondition was inferred, for the given AMethod.- Parameters:
m
- a methodexpression
- the expression- Returns:
- the declared type
-
getPostconditionDeclaredType
public AnnotatedTypeMirror getPostconditionDeclaredType(org.checkerframework.afu.scenelib.el.AMethod m, String expression) Fetches the declared type of an expression for which a postcondition was inferred, for the given AMethod.- Parameters:
m
- a methodexpression
- the expression- Returns:
- the declared type
-
addMethodDeclarationAnnotation
Description copied from interface:WholeProgramInferenceStorage
Updates a method to add a declaration annotation.- Specified by:
addMethodDeclarationAnnotation
in interfaceWholeProgramInferenceStorage<org.checkerframework.afu.scenelib.el.ATypeElement>
- Parameters:
methodElt
- the method to annotateanno
- the declaration annotation to add to the method- Returns:
- true if
anno
is a new declaration annotation formethodElt
, false otherwise
-
addFieldDeclarationAnnotation
Description copied from interface:WholeProgramInferenceStorage
Updates a field to add a declaration annotation.- Specified by:
addFieldDeclarationAnnotation
in interfaceWholeProgramInferenceStorage<org.checkerframework.afu.scenelib.el.ATypeElement>
- Parameters:
field
- the fieldanno
- the declaration annotation to add to the field- Returns:
- true if
anno
is a new declaration annotation forfieldElt
, false otherwise
-
addDeclarationAnnotationToFormalParameter
public boolean addDeclarationAnnotationToFormalParameter(ExecutableElement methodElt, int index, AnnotationMirror anno) Description copied from interface:WholeProgramInferenceStorage
Adds a declaration annotation to a formal parameter.- Specified by:
addDeclarationAnnotationToFormalParameter
in interfaceWholeProgramInferenceStorage<org.checkerframework.afu.scenelib.el.ATypeElement>
- Parameters:
methodElt
- the method whose formal parameter will be annotatedindex
- the index of the parameter (0-indexed)anno
- the annotation to add- Returns:
- true if
anno
is a new declaration annotation formethodElt
, false otherwise
-
addClassDeclarationAnnotation
Description copied from interface:WholeProgramInferenceStorage
Adds an annotation to a class declaration.- Specified by:
addClassDeclarationAnnotation
in interfaceWholeProgramInferenceStorage<org.checkerframework.afu.scenelib.el.ATypeElement>
- Parameters:
classElt
- the class declaration to annotateanno
- the annotation to add- Returns:
- true if
anno
is a new declaration annotation forclassElt
, false otherwise
-
writeScenes
Write all modified scenes into files. (Scenes are modified by the methodupdateAnnotationSetInScene(org.checkerframework.afu.scenelib.el.ATypeElement, org.checkerframework.framework.qual.TypeUseLocation, org.checkerframework.framework.type.AnnotatedTypeMirror, org.checkerframework.framework.type.AnnotatedTypeMirror, java.lang.String, boolean)
.)- Parameters:
outputFormat
- the output format to use when writing fileschecker
- the checker from which this method is called, for naming stub files
-
getJaifPath
Returns the String representing the .jaif path of a class given its name.- Parameters:
className
- the simple name of a class- Returns:
- the path to the .jaif file
-
getAClass
protected org.checkerframework.afu.scenelib.el.AClass getAClass(@BinaryName String className, String jaifPath, @Nullable com.sun.tools.javac.code.Symbol.ClassSymbol classSymbol) Returns the scene-lib representation of the given className in the scene identified by the given jaifPath.- Parameters:
className
- the name of the class to get, in binary formjaifPath
- the path to the jaif file that would represent that class (must end in ".jaif")classSymbol
- optionally, the ClassSymbol representing the class. Used to set the symbol information stored on an AClass.- Returns:
- a version of the scene-lib representation of the class, augmented with symbol
information if
classSymbol
was non-null
-
getAClass
protected org.checkerframework.afu.scenelib.el.AClass getAClass(@BinaryName String className, String jaifPath) Returns the scene-lib representation of the given className in the scene identified by the given jaifPath.- Parameters:
className
- the name of the class to get, in binary formjaifPath
- the path to the jaif file that would represent that class (must end in ".jaif")- Returns:
- the scene-lib representation of the class, possibly augmented with symbol information
if
getAClass(String, String, com.sun.tools.javac.code.Symbol.ClassSymbol)
has already been called with a non-null third argument
-
updateAnnotationSetInScene
protected void updateAnnotationSetInScene(org.checkerframework.afu.scenelib.el.ATypeElement type, TypeUseLocation defLoc, AnnotatedTypeMirror rhsATM, AnnotatedTypeMirror lhsATM, String jaifPath, boolean ignoreIfAnnotated) Updates the set of annotations in a location of a Scene, as the result of a pseudo-assignment.- If there was no previous annotation for that location, then the updated set will be the annotations in rhsATM.
- If there was a previous annotation, the updated set will be the LUB between the previous annotation and rhsATM.
- Parameters:
type
- ATypeElement of the Scene which will be modifiedjaifPath
- path to a .jaif file for a Scene; used for marking the scene as modified (needing to be written to disk)rhsATM
- the RHS of the annotated type on the source codelhsATM
- the LHS of the annotated type on the source codedefLoc
- the location where the annotation will be addedignoreIfAnnotated
- if true, don't update any type that is explicitly annotated in the source code
-
atmFromStorageLocation
public AnnotatedTypeMirror atmFromStorageLocation(TypeMirror typeMirror, org.checkerframework.afu.scenelib.el.ATypeElement storageLocation) Description copied from interface:WholeProgramInferenceStorage
Obtain the type from a storage location.- Specified by:
atmFromStorageLocation
in interfaceWholeProgramInferenceStorage<org.checkerframework.afu.scenelib.el.ATypeElement>
- Parameters:
typeMirror
- the underlying type for the resultstorageLocation
- the storage location from which to obtain annotations- Returns:
- an annotated type mirror with underlying type
typeMirror
and annotations fromstorageLocation
-
updateStorageLocationFromAtm
public void updateStorageLocationFromAtm(AnnotatedTypeMirror newATM, AnnotatedTypeMirror curATM, org.checkerframework.afu.scenelib.el.ATypeElement typeToUpdate, TypeUseLocation defLoc, boolean ignoreIfAnnotated) Description copied from interface:WholeProgramInferenceStorage
Updates a storage location to have the annotations of the givenAnnotatedTypeMirror
. Annotations in the original set that should be ignored are not added to the resulting set. IfignoreIfAnnotated
is true, doesn't add annotations for locations with explicit annotations in source code.This method removes from the storage location all annotations supported by the AnnotatedTypeFactory before inserting new ones. It is assumed that every time this method is called, the new
AnnotatedTypeMirror
has a better type estimate for the given location. Therefore, it is not a problem to remove all annotations before inserting the new annotations.The
update*
methods inWholeProgramInference
perform LUB. This one just does replacement. (Thus, the naming may be a bit confusing.)- Specified by:
updateStorageLocationFromAtm
in interfaceWholeProgramInferenceStorage<org.checkerframework.afu.scenelib.el.ATypeElement>
- Parameters:
newATM
- the type whose annotations will be added to theAnnotatedTypeMirror
curATM
- the annotations currently stored at the location, used to check if the element that will be updated has explicit annotations in source codetypeToUpdate
- the storage location that will be updateddefLoc
- the location where the annotation will be addedignoreIfAnnotated
- if true, don't update any type that is explicitly annotated in the source code
-
prepareSceneForWriting
public void prepareSceneForWriting(org.checkerframework.afu.scenelib.el.AScene compilationUnitAnnos) Side-effects the compilation unit annotations to make any desired changes before writing to a file.- Parameters:
compilationUnitAnnos
- the compilation unit annotations to modify
-
prepareClassForWriting
public void prepareClassForWriting(org.checkerframework.afu.scenelib.el.AClass classAnnos) Side-effects the class annotations to make any desired changes before writing to a file.- Parameters:
classAnnos
- the class annotations to modify
-
prepareMethodForWriting
public void prepareMethodForWriting(org.checkerframework.afu.scenelib.el.AMethod methodAnnos) Side-effects the method or constructor annotations to make any desired changes before writing to a file.- Parameters:
methodAnnos
- the method or constructor annotations to modify
-
writeResultsToFile
public void writeResultsToFile(WholeProgramInference.OutputFormat outputFormat, BaseTypeChecker checker) Description copied from interface:WholeProgramInferenceStorage
Writes the inferred results to a file. Ideally, it should be called at the end of the type-checking process. In practice, it is called after each class, because we don't know which class will be the last one in the type-checking process.- Specified by:
writeResultsToFile
in interfaceWholeProgramInferenceStorage<org.checkerframework.afu.scenelib.el.ATypeElement>
- Parameters:
outputFormat
- the file format in which to write the resultschecker
- the checker from which this method is called, for naming annotation files
-
setFileModified
Description copied from interface:WholeProgramInferenceStorage
Indicates that inferred annotations for the file atpath
have changed since last written. This causes output files forpath
to be written out next timeWholeProgramInferenceStorage.writeResultsToFile(org.checkerframework.common.wholeprograminference.WholeProgramInference.OutputFormat, org.checkerframework.common.basetype.BaseTypeChecker)
is called.- Specified by:
setFileModified
in interfaceWholeProgramInferenceStorage<org.checkerframework.afu.scenelib.el.ATypeElement>
- Parameters:
path
- path to the file with annotations that have been modified
-
preprocessClassTree
Description copied from interface:WholeProgramInferenceStorage
Performs any preparation required for inference on the elements of a class. Should be called on each top-level class declaration in a compilation unit before processing it.- Specified by:
preprocessClassTree
in interfaceWholeProgramInferenceStorage<org.checkerframework.afu.scenelib.el.ATypeElement>
- Parameters:
classTree
- the class to preprocess
-
aTypeElementToString
Returns a string representation of an ATypeElement, for use as part of a key inWholeProgramInferenceScenesStorage.AnnotationsInContexts
.- Parameters:
aType
- an ATypeElement to convert to a string representation- Returns:
- a string representation of the argument
-