Package it.unive.lisa.symbolic.value
Class HeapLocation
- java.lang.Object
-
- it.unive.lisa.symbolic.SymbolicExpression
-
- it.unive.lisa.symbolic.value.ValueExpression
-
- it.unive.lisa.symbolic.value.Identifier
-
- it.unive.lisa.symbolic.value.HeapLocation
-
- All Implemented Interfaces:
ScopedObject<SymbolicExpression>
public class HeapLocation extends Identifier
An identifier of a synthetic program variable that represents a resolved memory location.
-
-
Constructor Summary
Constructors Constructor Description HeapLocation(Type staticType, java.lang.String name, boolean weak, CodeLocation location)
Builds the heap location.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description <T> T
accept(ExpressionVisitor<T> visitor, java.lang.Object... params)
Accepts anExpressionVisitor
, visiting this expression recursively.boolean
canBeScoped()
Yieldstrue
if a call toSymbolicExpression.pushScope(ScopeToken)
on this identifier yields a newOutOfScopeIdentifier
associated with the given scope, that can then be removed bySymbolicExpression.popScope(ScopeToken)
.boolean
equals(java.lang.Object obj)
int
hashCode()
Identifier
lub(Identifier other)
Yields the least upper bounds between two identifiers.SymbolicExpression
popScope(ScopeToken token)
Pops the scope identified by the given token from the expression.SymbolicExpression
pushScope(ScopeToken token)
Pushes a new scope, identified by the give token, in the expression.java.lang.String
toString()
-
Methods inherited from class it.unive.lisa.symbolic.value.Identifier
addAnnotation, getAnnotations, getName, isScopedByCall, isWeak, mightNeedRewriting
-
Methods inherited from class it.unive.lisa.symbolic.value.ValueExpression
removeNegations
-
Methods inherited from class it.unive.lisa.symbolic.SymbolicExpression
getCodeLocation, getStaticType
-
-
-
-
Constructor Detail
-
HeapLocation
public HeapLocation(Type staticType, java.lang.String name, boolean weak, CodeLocation location)
Builds the heap location.- Parameters:
staticType
- the static type of this expressionname
- the name of the locationweak
- whether or not this identifier is weak, meaning that it should only receive weak assignmentslocation
- the code location of the statement that has generated this expression
-
-
Method Detail
-
toString
public java.lang.String toString()
- Specified by:
toString
in classSymbolicExpression
-
hashCode
public int hashCode()
- Overrides:
hashCode
in classIdentifier
-
equals
public boolean equals(java.lang.Object obj)
- Overrides:
equals
in classIdentifier
-
lub
public Identifier lub(Identifier other) throws SemanticException
Description copied from class:Identifier
Yields the least upper bounds between two identifiers.- Overrides:
lub
in classIdentifier
- Parameters:
other
- the other identifier- Returns:
- the least upper bounds between two identifiers.
- Throws:
SemanticException
- if this and other are not equal.
-
canBeScoped
public boolean canBeScoped()
Description copied from class:Identifier
Yieldstrue
if a call toSymbolicExpression.pushScope(ScopeToken)
on this identifier yields a newOutOfScopeIdentifier
associated with the given scope, that can then be removed bySymbolicExpression.popScope(ScopeToken)
. If this method returnsfalse
, thenSymbolicExpression.pushScope(ScopeToken)
andSymbolicExpression.popScope(ScopeToken)
will always return this identifier instead.- Specified by:
canBeScoped
in classIdentifier
- Returns:
true
if that condition holds
-
pushScope
public SymbolicExpression pushScope(ScopeToken token)
Description copied from class:SymbolicExpression
Pushes a new scope, identified by the give token, in the expression. This causes allIdentifier
s whereIdentifier.canBeScoped()
holds to becomeOutOfScopeIdentifier
s associated with the given token.- Specified by:
pushScope
in interfaceScopedObject<SymbolicExpression>
- Specified by:
pushScope
in classSymbolicExpression
- Parameters:
token
- the token identifying the scope to push- Returns:
- a copy of this expression where the local variables have gone out of scope
-
popScope
public SymbolicExpression popScope(ScopeToken token) throws SemanticException
Description copied from class:SymbolicExpression
Pops the scope identified by the given token from the expression. This causes all the invisible variables (i.e.OutOfScopeIdentifier
s) mapped to the given scope to become visible (e.g.Variable
s) again. Note that invoking this method onIdentifier
s whereIdentifier.canBeScoped()
holds will returnnull
if (i) the identifier is not scoped, or (ii) the identifier is scoped by a different token.- Specified by:
popScope
in interfaceScopedObject<SymbolicExpression>
- Specified by:
popScope
in classSymbolicExpression
- Parameters:
token
- the token of the scope to be restored- Returns:
- a copy of this expression where the local variables associated with the given scope are visible again
- Throws:
SemanticException
- if an error occurs during the computation
-
accept
public <T> T accept(ExpressionVisitor<T> visitor, java.lang.Object... params) throws SemanticException
Description copied from class:SymbolicExpression
Accepts anExpressionVisitor
, visiting this expression recursively.- Specified by:
accept
in classSymbolicExpression
- Type Parameters:
T
- the type of value produced by the visiting callbacks- Parameters:
visitor
- the visitorparams
- additional optional parameters to pass to each visiting callback- Returns:
- the value produced by the visiting operation
- Throws:
SemanticException
- if an error occurs during the visiting
-
-