Class LocalVariable
java.lang.Object
org.checkerframework.dataflow.expression.JavaExpression
org.checkerframework.dataflow.expression.LocalVariable
A local variable.
This class also represents a formal parameter expressed using its name. Class FormalParameter
represents a formal parameter expressed using the "#2" notation.
-
Field Summary
Modifier and TypeFieldDescriptionprotected final VariableElement
The element for this local variable.Fields inherited from class org.checkerframework.dataflow.expression.JavaExpression
type
-
Constructor Summary
ConstructorDescriptionLocalVariable
(VariableElement element) Creates a new LocalVariable.LocalVariable
(LocalVariableNode localVar) Creates a new LocalVariable. -
Method Summary
Modifier and TypeMethodDescription<R,
P> R accept
(JavaExpressionVisitor<R, P> visitor, P p) Accept method of the visitor pattern.boolean
containsOfClass
(Class<? extends JavaExpression> clazz) boolean
Returns true if and only if this contains a JavaExpression that is syntactically equal toother
.boolean
Returns the element for this variable.int
hashCode()
boolean
isDeterministic
(AnnotationProvider provider) Returns true if the expression is deterministic.boolean
Returns true if and only if the value this expression stands for cannot be changed (with respect to ==) by a method call.boolean
Returns true if and only if the value this expression stands for cannot be changed by a method call, including changes to any of its fields.protected static boolean
sameElement
(VariableElement element1, VariableElement element2) Returns true if the two elements are the same.boolean
Returns true if and only if the two Java expressions are syntactically identical.toString()
Format this verbosely, for debugging.Methods inherited from class org.checkerframework.dataflow.expression.JavaExpression
atConstructorInvocation, atFieldAccess, atMethodBody, atMethodInvocation, atMethodInvocation, containsModifiableAliasOf, containsUnknown, fromArrayAccess, fromNode, fromNodeFieldAccess, fromTree, fromVariableTree, getFormalParameters, getImplicitReceiver, getParametersAsLocalVariables, getPseudoReceiver, getReceiver, getType, listContainsSyntacticEqualJavaExpression, listIsDeterministic, syntacticEqualsList
-
Field Details
-
element
The element for this local variable.
-
-
Constructor Details
-
LocalVariable
Creates a new LocalVariable.- Parameters:
localVar
- a CFG local variable
-
LocalVariable
Creates a new LocalVariable.- Parameters:
element
- the element for the local variable
-
-
Method Details
-
equals
-
sameElement
Returns true if the two elements are the same.- Parameters:
element1
- the first element to compareelement2
- the second element to compare- Returns:
- true if the two elements are the same
-
getElement
Returns the element for this variable.- Returns:
- the element for this variable
-
hashCode
public int hashCode() -
toString
-
toStringDebug
Description copied from class:JavaExpression
Format this verbosely, for debugging.- Overrides:
toStringDebug
in classJavaExpression
- Returns:
- a verbose string representation of this
-
containsOfClass
- Specified by:
containsOfClass
in classJavaExpression
-
isDeterministic
Description copied from class:JavaExpression
Returns true if the expression is deterministic.- Specified by:
isDeterministic
in classJavaExpression
- Parameters:
provider
- an annotation provider (a type factory)- Returns:
- true if this expression is deterministic
-
syntacticEquals
Description copied from class:JavaExpression
Returns true if and only if the two Java expressions are syntactically identical.This exists for use by
JavaExpression.containsSyntacticEqualJavaExpression(org.checkerframework.dataflow.expression.JavaExpression)
.- Specified by:
syntacticEquals
in classJavaExpression
- Parameters:
je
- the other Java expression to compare to this one- Returns:
- true if and only if the two Java expressions are syntactically identical
-
containsSyntacticEqualJavaExpression
Description copied from class:JavaExpression
Returns true if and only if this contains a JavaExpression that is syntactically equal toother
.- Specified by:
containsSyntacticEqualJavaExpression
in classJavaExpression
- Parameters:
other
- the JavaExpression to search for- Returns:
- true if and only if this contains a JavaExpression that is syntactically equal to
other
-
isUnassignableByOtherCode
public boolean isUnassignableByOtherCode()Description copied from class:JavaExpression
Returns true if and only if the value this expression stands for cannot be changed (with respect to ==) by a method call. This is the case for local variables, the self reference, final field accesses whose receiver isJavaExpression.isUnassignableByOtherCode()
, and operations whose operands are allJavaExpression.isUnmodifiableByOtherCode()
.- Specified by:
isUnassignableByOtherCode
in classJavaExpression
- See Also:
-
isUnmodifiableByOtherCode
public boolean isUnmodifiableByOtherCode()Description copied from class:JavaExpression
Returns true if and only if the value this expression stands for cannot be changed by a method call, including changes to any of its fields.Approximately, this returns true if the expression is
JavaExpression.isUnassignableByOtherCode()
and its type is immutable.- Specified by:
isUnmodifiableByOtherCode
in classJavaExpression
- See Also:
-
accept
Description copied from class:JavaExpression
Accept method of the visitor pattern.- Specified by:
accept
in classJavaExpression
- Type Parameters:
R
- result type of the operationP
- parameter type- Parameters:
visitor
- the visitor to be applied to this JavaExpressionp
- the parameter for this operation- Returns:
- the result of visiting this
-