Class NullnessNoInitTransfer
- All Implemented Interfaces:
- ForwardTransferFunction<NullnessNoInitValue,,- NullnessNoInitStore> - TransferFunction<NullnessNoInitValue,,- NullnessNoInitStore> - NodeVisitor<TransferResult<NullnessNoInitValue,- NullnessNoInitStore>, - TransferInput<NullnessNoInitValue, - NullnessNoInitStore>> 
- After an expression is compared with the nullliteral, then that expression can safely be consideredNonNullif the result of the comparison is false orNullableif the result is true.
- If an expression is dereferenced, then it can safely be assumed to non-null in the future.
       If it would not be, then the dereference would have raised a NullPointerException.
- Tracks whether PolyNullis known to beNonNullorNullable(or not known to be either).
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected final @Nullable KeyForAnnotatedTypeFactoryThe type factory for the map key analysis, or null if the Map Key Checker should not be run.protected final AnnotatedTypeMirror.AnnotatedDeclaredTypeJava's Map interface.protected final AnnotationMirrorThe @NonNullannotation.protected final AnnotationMirrorThe @Nullableannotation.protected final NullnessNoInitAnnotatedTypeFactoryThe type factory for the nullness analysis that was passed to the constructor.protected final AnnotationMirrorThe @PolyNullannotation.Fields inherited from class org.checkerframework.framework.flow.CFAbstractTransferanalysis, sequentialSemantics
- 
Constructor SummaryConstructorsConstructorDescriptionNullnessNoInitTransfer(NullnessNoInitAnalysis analysis) Create a new NullnessTransfer for the given analysis.
- 
Method SummaryModifier and TypeMethodDescriptionprotected @Nullable NullnessNoInitValuefinishValue(@Nullable NullnessNoInitValue value, NullnessNoInitStore store) A hook for subclasses to modify the result of the transfer function.protected @Nullable NullnessNoInitValuefinishValue(@Nullable NullnessNoInitValue value, NullnessNoInitStore thenStore, NullnessNoInitStore elseStore) A hook for subclasses to modify the result of the transfer function.protected voidmakeNonNull(NullnessNoInitStore store, Node node) Sets a givenNodeto non-null in the givenstore.protected voidmakeNonNull(TransferResult<NullnessNoInitValue, NullnessNoInitStore> result, Node node) Sets a given node to non-null in the given transfer result.protected voidRefine the given result to @NonNull.protected TransferResult<NullnessNoInitValue, NullnessNoInitStore> strengthenAnnotationOfEqualTo(TransferResult<NullnessNoInitValue, NullnessNoInitStore> res, Node firstNode, Node secondNode, NullnessNoInitValue firstValue, NullnessNoInitValue secondValue, boolean notEqualTo) Refine the annotation ofsecondNodeif the annotationsecondValueis less precise thanfirstValue.visitMethodInvocation(MethodInvocationNode n, TransferInput<NullnessNoInitValue, NullnessNoInitStore> in) Methods inherited from class org.checkerframework.framework.flow.CFAbstractTransferaddInformationFromPreconditions, createTransferResult, getNarrowedValue, getValueFromFactory, getWidenedValue, initialStore, insertIntoStores, isNotFullyInitializedReceiver, moreSpecificValue, processCommonAssignment, processConditionalPostconditions, processPostconditions, recreateTransferResult, setFixedInitialStore, splitAssignments, usesSequentialSemantics, visitAssignment, visitCase, visitClassName, visitConditionalNot, visitDeconstructorPattern, visitEqualTo, visitExpressionStatement, visitLambdaResultExpression, visitLocalVariable, visitNarrowingConversion, visitNode, visitNotEqual, visitObjectCreation, visitStringConversion, visitSwitchExpressionNode, visitTernaryExpression, visitThis, visitVariableDeclaration, visitWideningConversionMethods inherited from class org.checkerframework.dataflow.cfg.node.AbstractNodeVisitorvisitArrayCreation, visitArrayType, visitAssertionError, visitBitwiseAnd, visitBitwiseComplement, visitBitwiseOr, visitBitwiseXor, visitBooleanLiteral, visitCharacterLiteral, visitClassDeclaration, visitConditionalAnd, visitConditionalOr, visitDoubleLiteral, visitExplicitThis, visitFloatingDivision, visitFloatingRemainder, visitFloatLiteral, visitGreaterThan, visitGreaterThanOrEqual, visitImplicitThis, visitIntegerDivision, visitIntegerLiteral, visitIntegerRemainder, visitLeftShift, visitLessThan, visitLessThanOrEqual, visitLongLiteral, visitMarker, visitMemberReference, visitNullChk, visitNullLiteral, visitNumericalAddition, visitNumericalMinus, visitNumericalMultiplication, visitNumericalPlus, visitNumericalSubtraction, visitPackageName, visitParameterizedType, visitPrimitiveType, visitShortLiteral, visitSignedRightShift, visitStringConcatenate, visitStringLiteral, visitSuper, visitSynchronized, visitTypeCast, visitUnsignedRightShift, visitValueLiteralMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.checkerframework.dataflow.cfg.node.NodeVisitorvisitArrayCreation, visitArrayType, visitAssertionError, visitBitwiseAnd, visitBitwiseComplement, visitBitwiseOr, visitBitwiseXor, visitBooleanLiteral, visitCharacterLiteral, visitClassDeclaration, visitConditionalAnd, visitConditionalOr, visitDoubleLiteral, visitExplicitThis, visitFloatingDivision, visitFloatingRemainder, visitFloatLiteral, visitGreaterThan, visitGreaterThanOrEqual, visitImplicitThis, visitIntegerDivision, visitIntegerLiteral, visitIntegerRemainder, visitLeftShift, visitLessThan, visitLessThanOrEqual, visitLongLiteral, visitMarker, visitMemberReference, visitNullChk, visitNullLiteral, visitNumericalAddition, visitNumericalMinus, visitNumericalMultiplication, visitNumericalPlus, visitNumericalSubtraction, visitPackageName, visitParameterizedType, visitPrimitiveType, visitShortLiteral, visitSignedRightShift, visitStringConcatenate, visitStringLiteral, visitSuper, visitSynchronized, visitTypeCast, visitUnsignedRightShift
- 
Field Details- 
NONNULLThe @NonNullannotation.
- 
NULLABLEThe @Nullableannotation.
- 
POLYNULLThe @PolyNullannotation.
- 
MAP_TYPEJava's Map interface.The qualifiers in this type don't matter -- it is not used as a fully-annotated AnnotatedDeclaredType, but just passed to asSuper(). 
- 
nullnessTypeFactoryThe type factory for the nullness analysis that was passed to the constructor.
- 
keyForTypeFactoryThe type factory for the map key analysis, or null if the Map Key Checker should not be run.
 
- 
- 
Constructor Details- 
NullnessNoInitTransferCreate a new NullnessTransfer for the given analysis.- Parameters:
- analysis- nullness analysis
 
 
- 
- 
Method Details- 
makeNonNullSets a givenNodeto non-null in the givenstore. Calls to this method implement case 2.- Parameters:
- store- the store to update
- node- the node that should be non-null
 
- 
makeNonNullprotected void makeNonNull(TransferResult<NullnessNoInitValue, NullnessNoInitStore> result, Node node) Sets a given node to non-null in the given transfer result.- Parameters:
- result- the transfer result
- node- the node to make non-null
 
- 
refineToNonNullRefine the given result to @NonNull.- Parameters:
- result- the result to refine
 
- 
finishValueprotected @Nullable NullnessNoInitValue finishValue(@Nullable NullnessNoInitValue value, NullnessNoInitStore store) Description copied from class:CFAbstractTransferA hook for subclasses to modify the result of the transfer function. This method is called before returning the abstract valuevalueas the result of the transfer function.If a subclass overrides this method, the subclass should also override CFAbstractTransfer.finishValue(CFAbstractValue,CFAbstractStore,CFAbstractStore).- Overrides:
- finishValuein class- CFAbstractTransfer<NullnessNoInitValue,- NullnessNoInitStore, - NullnessNoInitTransfer> 
- Parameters:
- value- a value to possibly modify
- store- the store
- Returns:
- the possibly-modified value
 
- 
finishValueprotected @Nullable NullnessNoInitValue finishValue(@Nullable NullnessNoInitValue value, NullnessNoInitStore thenStore, NullnessNoInitStore elseStore) Description copied from class:CFAbstractTransferA hook for subclasses to modify the result of the transfer function. This method is called before returning the abstract valuevalueas the result of the transfer function.If a subclass overrides this method, the subclass should also override CFAbstractTransfer.finishValue(CFAbstractValue,CFAbstractStore).- Overrides:
- finishValuein class- CFAbstractTransfer<NullnessNoInitValue,- NullnessNoInitStore, - NullnessNoInitTransfer> 
- Parameters:
- value- the value to finish
- thenStore- the "then" store
- elseStore- the "else" store
- Returns:
- the possibly-modified value
 
- 
strengthenAnnotationOfEqualToprotected TransferResult<NullnessNoInitValue,NullnessNoInitStore> strengthenAnnotationOfEqualTo(TransferResult<NullnessNoInitValue, NullnessNoInitStore> res, Node firstNode, Node secondNode, NullnessNoInitValue firstValue, NullnessNoInitValue secondValue, boolean notEqualTo) Refine the annotation ofsecondNodeif the annotationsecondValueis less precise thanfirstValue. This is possible, ifsecondNodeis an expression that is tracked by the store (e.g., a local variable or a field). Clients usually call this twice withfirstNodeandsecondNodereversed, to refine each of them.Note that when overriding this method, when a new type is inserted into the store, CFAbstractTransfer.splitAssignments(org.checkerframework.dataflow.cfg.node.Node)should be called, and the new type should be inserted into the store for each of the resulting nodes.Furthermore, this method refines the type to NonNullfor the appropriate branch if an expression is compared to thenullliteral (listed as case 1 in the class description).- Overrides:
- strengthenAnnotationOfEqualToin class- CFAbstractTransfer<NullnessNoInitValue,- NullnessNoInitStore, - NullnessNoInitTransfer> 
- Parameters:
- res- the previous result
- firstNode- the node that might be more precise
- secondNode- the node whose type to possibly refine
- firstValue- the abstract value that might be more precise
- secondValue- the abstract value that might be less precise
- notEqualTo- if true, indicates that the logic is flipped (i.e., the information is added to the- elseStoreinstead of the- thenStore) for a not-equal comparison.
- Returns:
- the conditional transfer result (if information has been added), or res
 
- 
visitArrayAccesspublic TransferResult<NullnessNoInitValue,NullnessNoInitStore> visitArrayAccess(ArrayAccessNode n, TransferInput<NullnessNoInitValue, NullnessNoInitStore> p) - Specified by:
- visitArrayAccessin interface- NodeVisitor<TransferResult<NullnessNoInitValue,- NullnessNoInitStore>, - TransferInput<NullnessNoInitValue, - NullnessNoInitStore>> 
- Overrides:
- visitArrayAccessin class- CFAbstractTransfer<NullnessNoInitValue,- NullnessNoInitStore, - NullnessNoInitTransfer> 
 
- 
visitInstanceOfpublic TransferResult<NullnessNoInitValue,NullnessNoInitStore> visitInstanceOf(InstanceOfNode n, TransferInput<NullnessNoInitValue, NullnessNoInitStore> p) - Specified by:
- visitInstanceOfin interface- NodeVisitor<TransferResult<NullnessNoInitValue,- NullnessNoInitStore>, - TransferInput<NullnessNoInitValue, - NullnessNoInitStore>> 
- Overrides:
- visitInstanceOfin class- CFAbstractTransfer<NullnessNoInitValue,- NullnessNoInitStore, - NullnessNoInitTransfer> 
 
- 
visitMethodAccesspublic TransferResult<NullnessNoInitValue,NullnessNoInitStore> visitMethodAccess(MethodAccessNode n, TransferInput<NullnessNoInitValue, NullnessNoInitStore> p) - Specified by:
- visitMethodAccessin interface- NodeVisitor<TransferResult<NullnessNoInitValue,- NullnessNoInitStore>, - TransferInput<NullnessNoInitValue, - NullnessNoInitStore>> 
- Overrides:
- visitMethodAccessin class- AbstractNodeVisitor<TransferResult<NullnessNoInitValue,- NullnessNoInitStore>, - TransferInput<NullnessNoInitValue, - NullnessNoInitStore>> 
 
- 
visitFieldAccesspublic TransferResult<NullnessNoInitValue,NullnessNoInitStore> visitFieldAccess(FieldAccessNode n, TransferInput<NullnessNoInitValue, NullnessNoInitStore> p) - Specified by:
- visitFieldAccessin interface- NodeVisitor<TransferResult<NullnessNoInitValue,- NullnessNoInitStore>, - TransferInput<NullnessNoInitValue, - NullnessNoInitStore>> 
- Overrides:
- visitFieldAccessin class- CFAbstractTransfer<NullnessNoInitValue,- NullnessNoInitStore, - NullnessNoInitTransfer> 
 
- 
visitThrowpublic TransferResult<NullnessNoInitValue,NullnessNoInitStore> visitThrow(ThrowNode n, TransferInput<NullnessNoInitValue, NullnessNoInitStore> p) - Specified by:
- visitThrowin interface- NodeVisitor<TransferResult<NullnessNoInitValue,- NullnessNoInitStore>, - TransferInput<NullnessNoInitValue, - NullnessNoInitStore>> 
- Overrides:
- visitThrowin class- AbstractNodeVisitor<TransferResult<NullnessNoInitValue,- NullnessNoInitStore>, - TransferInput<NullnessNoInitValue, - NullnessNoInitStore>> 
 
- 
visitMethodInvocationpublic TransferResult<NullnessNoInitValue,NullnessNoInitStore> visitMethodInvocation(MethodInvocationNode n, TransferInput<NullnessNoInitValue, NullnessNoInitStore> in) When the conservativeArgumentNullnessAfterInvocation flag is turned off, the receiver and arguments that are passed to non-null parameters in a method call or constructor invocation are unsoundly assumed to be non-null after the invocation. When the flag is turned on, the analysis is more conservative by checking the method is SideEffectFree or the receiver is unassignable. Only if either one of the two is true, is the receiver made non-null. Similar logic is applied to the arguments of the invocation. Provided that m is of a type that implements interface java.util.Map: - Given a call m.get(k), if k is @KeyFor("m") and m's value type is @NonNull, then the result is @NonNull in the thenStore and elseStore of the transfer result.
 - Specified by:
- visitMethodInvocationin interface- NodeVisitor<TransferResult<NullnessNoInitValue,- NullnessNoInitStore>, - TransferInput<NullnessNoInitValue, - NullnessNoInitStore>> 
- Overrides:
- visitMethodInvocationin class- CFAbstractTransfer<NullnessNoInitValue,- NullnessNoInitStore, - NullnessNoInitTransfer> 
 
- 
visitReturnpublic TransferResult<NullnessNoInitValue,NullnessNoInitStore> visitReturn(ReturnNode n, TransferInput<NullnessNoInitValue, NullnessNoInitStore> in) - Specified by:
- visitReturnin interface- NodeVisitor<TransferResult<NullnessNoInitValue,- NullnessNoInitStore>, - TransferInput<NullnessNoInitValue, - NullnessNoInitStore>> 
- Overrides:
- visitReturnin class- CFAbstractTransfer<NullnessNoInitValue,- NullnessNoInitStore, - NullnessNoInitTransfer> 
 
 
-