public class ClassName extends JavaExpression
type
Constructor and Description |
---|
ClassName(TypeMirror type)
Creates a new ClassName object for the given type.
|
Modifier and Type | Method and Description |
---|---|
<R,P> R |
accept(JavaExpressionVisitor<R,P> visitor,
P p)
Accept method of the visitor pattern.
|
boolean |
containsModifiableAliasOf(Store<?> store,
JavaExpression other)
Returns true if and only if
other appears anywhere in this or an expression appears in
this such that other might alias this expression, and that expression is modifiable. |
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) |
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.
|
boolean |
syntacticEquals(JavaExpression je)
Returns true if and only if the two Java expressions are syntactically identical.
|
String |
toString() |
atConstructorInvocation, atFieldAccess, atMethodBody, atMethodInvocation, atMethodInvocation, containsUnknown, fromArrayAccess, fromNode, fromNodeFieldAccess, fromTree, fromVariableTree, getFormalParameters, getImplicitReceiver, getParametersAsLocalVariables, getPseudoReceiver, getReceiver, getType, listContainsSyntacticEqualJavaExpression, listIsDeterministic, toStringDebug
public ClassName(TypeMirror type)
type
- the type for the new ClassName. If it will represent a class literal, the type is
declared primitive, void, or array of one of them. If it represents part of a static field
access or static method invocation, the type is declared, type variable, or array
(including array of primitive).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 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 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 containsModifiableAliasOf(Store<?> store, JavaExpression other)
JavaExpression
other
appears anywhere in this or an expression appears in
this such that other
might alias this expression, and that expression is modifiable.
This is always true, except for cases where the Java type information prevents aliasing and none of the subexpressions can alias 'other'.
containsModifiableAliasOf
in class JavaExpression
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