public class LocalVariable extends JavaExpression
This class also represents a formal parameter expressed using its name. Class FormalParameter
represents a formal parameter expressed using the "#2" notation.
Modifier and Type | Field and Description |
---|---|
protected VariableElement |
element
The element for this local variable.
|
type
Constructor and Description |
---|
LocalVariable(LocalVariableNode localVar)
Creates a new LocalVariable.
|
LocalVariable(VariableElement element)
Creates a new LocalVariable.
|
Modifier and Type | Method and Description |
---|---|
<R,P> R |
accept(JavaExpressionVisitor<R,P> visitor,
P p)
Accept method of the visitor pattern.
|
boolean |
containsOfClass(Class<? extends JavaExpression> clazz) |
boolean |
containsSyntacticEqualJavaExpression(JavaExpression other)
Returns true if and only if this contains a JavaExpression that is syntactically equal to
other . |
boolean |
equals(@Nullable Object obj) |
VariableElement |
getElement()
Returns the element for this variable.
|
int |
hashCode() |
boolean |
isDeterministic(AnnotationProvider provider)
Returns true if the expression is deterministic.
|
boolean |
isUnassignableByOtherCode()
Returns true if and only if the value this expression stands for cannot be changed (with
respect to ==) by a method call.
|
boolean |
isUnmodifiableByOtherCode()
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 |
syntacticEquals(JavaExpression je)
Returns true if and only if the two Java expressions are syntactically identical.
|
String |
toString() |
String |
toStringDebug()
Format this verbosely, for debugging.
|
atConstructorInvocation, atFieldAccess, atMethodBody, atMethodInvocation, atMethodInvocation, containsModifiableAliasOf, containsUnknown, fromArrayAccess, fromNode, fromNodeFieldAccess, fromTree, fromVariableTree, getFormalParameters, getImplicitReceiver, getParametersAsLocalVariables, getPseudoReceiver, getReceiver, getType, listContainsSyntacticEqualJavaExpression, listIsDeterministic
protected final VariableElement element
public LocalVariable(LocalVariableNode localVar)
localVar
- a CFG local variablepublic LocalVariable(VariableElement element)
element
- the element for the local variableprotected static boolean sameElement(VariableElement element1, VariableElement element2)
element1
- the first element to compareelement2
- the second element to comparepublic VariableElement getElement()
public String toStringDebug()
JavaExpression
toStringDebug
in class JavaExpression
public boolean containsOfClass(Class<? extends JavaExpression> clazz)
containsOfClass
in class JavaExpression
public boolean isDeterministic(AnnotationProvider provider)
JavaExpression
isDeterministic
in class JavaExpression
provider
- an annotation provider (a type factory)public boolean syntacticEquals(JavaExpression je)
JavaExpression
This exists for use by JavaExpression.containsSyntacticEqualJavaExpression(org.checkerframework.dataflow.expression.JavaExpression)
.
syntacticEquals
in class JavaExpression
je
- the other Java expression to compare to this onepublic boolean containsSyntacticEqualJavaExpression(JavaExpression other)
JavaExpression
other
.containsSyntacticEqualJavaExpression
in class JavaExpression
other
- the JavaExpression to search forother
public boolean isUnassignableByOtherCode()
JavaExpression
JavaExpression.isUnassignableByOtherCode()
, and operations whose
operands are all JavaExpression.isUnmodifiableByOtherCode()
.isUnassignableByOtherCode
in class JavaExpression
JavaExpression.isUnmodifiableByOtherCode()
public boolean isUnmodifiableByOtherCode()
JavaExpression
Approximately, this returns true if the expression is JavaExpression.isUnassignableByOtherCode()
and
its type is immutable.
isUnmodifiableByOtherCode
in class JavaExpression
JavaExpression.isUnassignableByOtherCode()
public <R,P> R accept(JavaExpressionVisitor<R,P> visitor, P p)
JavaExpression
accept
in class JavaExpression
R
- result type of the operationP
- parameter typevisitor
- the visitor to be applied to this JavaExpressionp
- the parameter for this operation