Class InitializationStore
java.lang.Object
org.checkerframework.framework.flow.CFAbstractStore<CFValue,InitializationStore>
org.checkerframework.checker.initialization.InitializationStore
- All Implemented Interfaces:
Store<InitializationStore>
,org.plumelib.util.UniqueId
A store that extends
CFAbstractStore
and additionally tracks which fields of the 'self'
reference have been initialized.- See Also:
-
Nested Class Summary
Nested classes/interfaces inherited from interface org.checkerframework.dataflow.analysis.Store
Store.FlowRule, Store.Kind
-
Field Summary
Modifier and TypeFieldDescriptionprotected final Set
<VariableElement> The set of fields that are initialized.Fields inherited from class org.checkerframework.framework.flow.CFAbstractStore
analysis, arrayValues, classValues, fieldValues, localVariableValues, methodValues, sequentialSemantics, thisValue
-
Constructor Summary
ConstructorDescriptionInitializationStore
(InitializationAnalysis analysis, boolean sequentialSemantics) Creates a new InitializationStore.A copy constructor. -
Method Summary
Modifier and TypeMethodDescriptionvoid
Mark the field identified by the elementf
as initialized (the caller needs to ensure that the field belongs to the current class, or is a static field).void
addInitializedField
(FieldAccess field) Mark the field identified by the elementfield
as initialized if it belongs to the current class, or is static (in which case there is no aliasing issue and we can just add all static fields).Returns the analysis associated with this store.void
insertValue
(JavaExpression je, CFValue value, boolean permitNondeterministic) protected String
Adds a representation of the internal information of this Store to visualizerviz
.protected boolean
isDeclaredInitialized
(FieldAccess fieldAccess) Determine whether the given field is declared asInitialized
(taking into account viewpoint adaption forNotOnlyInitialized
).boolean
Is the field identified by the elementf
initialized?Compute the least upper bound of two stores.protected CFValue
newFieldValueAfterMethodCall
(FieldAccess fieldAccess, GenericAnnotatedTypeFactory<CFValue, InitializationStore, ?, ?> atypeFactory, CFValue value) Returns the new value of a field after a method call, ornull
if the field should be removed from the store.protected boolean
Returns true iff thisCFAbstractStore
contains a superset of the map entries of the argumentCFAbstractStore
.Methods inherited from class org.checkerframework.framework.flow.CFAbstractStore
canAlias, canInsertJavaExpression, clearValue, computeNewValueAndInsert, copy, equals, getFieldValue, getFieldValues, getUid, getValue, getValue, getValue, getValue, getValue, getValue, hashCode, initializeMethodParameter, initializeThisValue, insertOrRefine, insertOrRefine, insertOrRefinePermitNondeterministic, insertThisValue, insertValue, insertValue, insertValuePermitNondeterministic, insertValuePermitNondeterministic, isMonotonicUpdate, isSideEffectFree, newMonotonicFieldValueAfterMethodCall, removeConflicting, removeConflicting, removeConflicting, replaceValue, shouldInsert, toString, updateForArrayAssignment, updateForAssignment, updateForFieldAccessAssignment, updateForLocalVariableAssignment, updateForMethodCall, visualize, widenedUpperBound
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
Methods inherited from interface org.plumelib.util.UniqueId
getClassAndUid
-
Field Details
-
initializedFields
The set of fields that are initialized.
-
-
Constructor Details
-
InitializationStore
Creates a new InitializationStore.- Parameters:
analysis
- the analysis class this store belongs tosequentialSemantics
- should the analysis use sequential Java semantics?
-
InitializationStore
A copy constructor.- Parameters:
other
- the store to copy
-
-
Method Details
-
insertValue
Helper method forCFAbstractStore.insertValue(JavaExpression, CFAbstractValue)
andCFAbstractStore.insertValuePermitNondeterministic(org.checkerframework.dataflow.expression.JavaExpression, javax.lang.model.element.AnnotationMirror)
.Every overriding implementation should start with
if (!shouldInsert) { return; }
If the receiver is a field, and has an invariant annotation, then it can be considered initialized.
- Overrides:
insertValue
in classCFAbstractStore<CFValue,
InitializationStore> - Parameters:
je
- the expression to insert in the storevalue
- the value of the expressionpermitNondeterministic
- if false, does nothing ifexpr
is nondeterministic; if true, permits nondeterministic expressions to be placed in the store
-
addInitializedField
Mark the field identified by the elementfield
as initialized if it belongs to the current class, or is static (in which case there is no aliasing issue and we can just add all static fields).- Parameters:
field
- a field that is initialized
-
addInitializedField
Mark the field identified by the elementf
as initialized (the caller needs to ensure that the field belongs to the current class, or is a static field).- Parameters:
f
- a field that is initialized
-
isFieldInitialized
Is the field identified by the elementf
initialized? -
supersetOf
Description copied from class:CFAbstractStore
Returns true iff thisCFAbstractStore
contains a superset of the map entries of the argumentCFAbstractStore
. Note that we test the entry keys and values by Java equality, not by any subtype relationship. This method is used primarily to simplify the equals predicate.- Overrides:
supersetOf
in classCFAbstractStore<CFValue,
InitializationStore>
-
leastUpperBound
Description copied from interface:Store
Compute the least upper bound of two stores.Important: This method must fulfill the following contract:
- Does not change
this
. - Does not change
other
. - Returns a fresh object which is not aliased yet.
- Returns an object of the same (dynamic) type as
this
, even if the signature is more permissive. - Is commutative.
- Specified by:
leastUpperBound
in interfaceStore<InitializationStore>
- Overrides:
leastUpperBound
in classCFAbstractStore<CFValue,
InitializationStore>
- Does not change
-
newFieldValueAfterMethodCall
protected CFValue newFieldValueAfterMethodCall(FieldAccess fieldAccess, GenericAnnotatedTypeFactory<CFValue, InitializationStore, ?, ?> atypeFactory, CFValue value) Description copied from class:CFAbstractStore
Returns the new value of a field after a method call, ornull
if the field should be removed from the store.In this default implementation, the field's value is preserved if it is either unassignable (see
FieldAccess.isUnassignableByOtherCode()
) or has a monotonic qualifier (seeCFAbstractStore.newMonotonicFieldValueAfterMethodCall(FieldAccess, GenericAnnotatedTypeFactory, CFAbstractValue)
). Otherwise, it is removed from the store.- Overrides:
newFieldValueAfterMethodCall
in classCFAbstractStore<CFValue,
InitializationStore> - Parameters:
fieldAccess
- the field whose value to updateatypeFactory
- AnnotatedTypeFactory of the associated checkervalue
- the field's value before the method call- Returns:
- the field's value after the method call, or
null
if the field should be removed from the store
-
isDeclaredInitialized
Determine whether the given field is declared asInitialized
(taking into account viewpoint adaption forNotOnlyInitialized
).- Parameters:
fieldAccess
- the field to check- Returns:
- whether the given field is declared as
Initialized
(taking into account viewpoint adaption forNotOnlyInitialized
)
-
internalVisualize
Description copied from class:CFAbstractStore
Adds a representation of the internal information of this Store to visualizerviz
.- Overrides:
internalVisualize
in classCFAbstractStore<CFValue,
InitializationStore> - Parameters:
viz
- the visualizer- Returns:
- a representation of the internal information of this
Store
-
getAnalysis
Returns the analysis associated with this store.- Returns:
- the analysis associated with this store
-