Enum move_model::ast::ExpData
source · [−]pub enum ExpData {
Invalid(NodeId),
Value(NodeId, Value),
LocalVar(NodeId, Symbol),
Temporary(NodeId, TempIndex),
Call(NodeId, Operation, Vec<Exp>),
Invoke(NodeId, Exp, Vec<Exp>),
Lambda(NodeId, Vec<LocalVarDecl>, Exp),
Quant(NodeId, QuantKind, Vec<(LocalVarDecl, Exp)>, Vec<Vec<Exp>>, Option<Exp>, Exp),
Block(NodeId, Vec<LocalVarDecl>, Exp),
IfElse(NodeId, Exp, Exp, Exp),
}
Expand description
The type of expression data.
Expression layout follows the following design principles:
- We try to keep the number of expression variants minimal, for easier treatment in
generic traversals. Builtin and user functions are abstracted into a general
Call(.., operation, args)
construct. - Each expression has a unique node id assigned. This id allows to build attribute tables for additional information, like expression type and source location. The id is globally unique.
Variants
Invalid(NodeId)
Represents an invalid expression. This is used as a stub for algorithms which generate expressions but can fail with multiple errors, like a translator from some other source into expressions. Consumers of expressions should assume this variant is not present and can panic when seeing it.
Value(NodeId, Value)
Represents a value.
LocalVar(NodeId, Symbol)
Represents a reference to a local variable introduced by a specification construct, e.g. a quantifier.
Temporary(NodeId, TempIndex)
Represents a reference to a temporary used in bytecode.
Call(NodeId, Operation, Vec<Exp>)
Represents a call to an operation. The Operation
enum covers all builtin functions
(including operators, constants, …) as well as user functions.
Invoke(NodeId, Exp, Vec<Exp>)
Represents an invocation of a function value, as a lambda.
Lambda(NodeId, Vec<LocalVarDecl>, Exp)
Represents a lambda.
Quant(NodeId, QuantKind, Vec<(LocalVarDecl, Exp)>, Vec<Vec<Exp>>, Option<Exp>, Exp)
Represents a quantified formula over multiple variables and ranges.
Block(NodeId, Vec<LocalVarDecl>, Exp)
Represents a block which contains a set of variable bindings and an expression for which those are defined.
IfElse(NodeId, Exp, Exp, Exp)
Represents a conditional.
Implementations
sourceimpl ExpData
impl ExpData
pub fn ptr_eq(e1: &Exp, e2: &Exp) -> bool
pub fn node_id(&self) -> NodeId
pub fn call_args(&self) -> &[Exp]
pub fn node_ids(&self) -> Vec<NodeId>ⓘNotable traits for Vec<u8, A>impl<A> Write for Vec<u8, A> where
A: Allocator,
A: Allocator,
sourcepub fn free_vars(&self, env: &GlobalEnv) -> Vec<(Symbol, Type)>ⓘNotable traits for Vec<u8, A>impl<A> Write for Vec<u8, A> where
A: Allocator,
pub fn free_vars(&self, env: &GlobalEnv) -> Vec<(Symbol, Type)>ⓘNotable traits for Vec<u8, A>impl<A> Write for Vec<u8, A> where
A: Allocator,
A: Allocator,
Returns the free local variables, inclusive their types, used in this expression. Result is ordered by occurrence.
sourcepub fn used_memory(
&self,
env: &GlobalEnv
) -> BTreeSet<(QualifiedInstId<StructId>, Option<MemoryLabel>)>
pub fn used_memory(
&self,
env: &GlobalEnv
) -> BTreeSet<(QualifiedInstId<StructId>, Option<MemoryLabel>)>
Returns the used memory of this expression.
sourcepub fn used_temporaries(&self, env: &GlobalEnv) -> Vec<(TempIndex, Type)>ⓘNotable traits for Vec<u8, A>impl<A> Write for Vec<u8, A> where
A: Allocator,
pub fn used_temporaries(&self, env: &GlobalEnv) -> Vec<(TempIndex, Type)>ⓘNotable traits for Vec<u8, A>impl<A> Write for Vec<u8, A> where
A: Allocator,
A: Allocator,
Returns the temporaries used in this expression. Result is ordered by occurrence.
sourcepub fn visit<F>(&self, visitor: &mut F) where
F: FnMut(&ExpData),
pub fn visit<F>(&self, visitor: &mut F) where
F: FnMut(&ExpData),
Visits expression, calling visitor on each sub-expression, depth first.
pub fn any<P>(&self, predicate: &mut P) -> bool where
P: FnMut(&ExpData) -> bool,
sourcepub fn visit_pre_post<F>(&self, visitor: &mut F) where
F: FnMut(bool, &ExpData),
pub fn visit_pre_post<F>(&self, visitor: &mut F) where
F: FnMut(bool, &ExpData),
Visits expression, calling visitor on each sub-expression. visitor(false, ..)
will
be called before descending into expression, and visitor(true, ..)
after. Notice
we use one function instead of two so a lambda can be passed which encapsulates mutable
references.
sourcepub fn rewrite<F>(exp: Exp, exp_rewriter: &mut F) -> Exp where
F: FnMut(Exp) -> Result<Exp, Exp>,
pub fn rewrite<F>(exp: Exp, exp_rewriter: &mut F) -> Exp where
F: FnMut(Exp) -> Result<Exp, Exp>,
Rewrites this expression and sub-expression based on the rewriter function. The
function returns Ok(e)
if the expression is rewritten, and passes back ownership
using Err(e)
if the expression stays unchanged. This function stops traversing
on Ok(e)
and descents into sub-expressions on Err(e)
.
sourcepub fn rewrite_node_id<F>(exp: Exp, node_rewriter: &mut F) -> Exp where
F: FnMut(NodeId) -> Option<NodeId>,
pub fn rewrite_node_id<F>(exp: Exp, node_rewriter: &mut F) -> Exp where
F: FnMut(NodeId) -> Option<NodeId>,
Rewrites the node ids in the expression. This is used to rewrite types of expressions.
sourcepub fn rewrite_exp_and_node_id<F, G>(
exp: Exp,
exp_rewriter: &mut F,
node_rewriter: &mut G
) -> Exp where
F: FnMut(Exp) -> Result<Exp, Exp>,
G: FnMut(NodeId) -> Option<NodeId>,
pub fn rewrite_exp_and_node_id<F, G>(
exp: Exp,
exp_rewriter: &mut F,
node_rewriter: &mut G
) -> Exp where
F: FnMut(Exp) -> Result<Exp, Exp>,
G: FnMut(NodeId) -> Option<NodeId>,
Rewrites the expression and for unchanged sub-expressions, the node ids in the expression
sourcepub fn instantiate_node(
env: &GlobalEnv,
id: NodeId,
targs: &[Type]
) -> Option<NodeId>
pub fn instantiate_node(
env: &GlobalEnv,
id: NodeId,
targs: &[Type]
) -> Option<NodeId>
A function which can be used for Exp::rewrite_node_id
to instantiate types in
an expression based on a type parameter instantiation.
sourcepub fn module_usage(&self, usage: &mut BTreeSet<ModuleId>)
pub fn module_usage(&self, usage: &mut BTreeSet<ModuleId>)
Returns the set of module ids used by this expression.
sourcepub fn extract_ghost_mem_access(
&self,
env: &GlobalEnv
) -> Option<(QualifiedInstId<StructId>, FieldId, Exp)>
pub fn extract_ghost_mem_access(
&self,
env: &GlobalEnv
) -> Option<(QualifiedInstId<StructId>, FieldId, Exp)>
Extract access to ghost memory from expression. Returns a tuple of the instantiated struct, the field of the selected value, and the expression with the address of the access.
sourcepub fn struct_usage(&self, usage: &mut BTreeSet<QualifiedId<StructId>>)
pub fn struct_usage(&self, usage: &mut BTreeSet<QualifiedId<StructId>>)
Collect struct-related operations
sourcepub fn field_usage(
&self,
usage: &mut BTreeSet<(QualifiedId<StructId>, FieldId)>
)
pub fn field_usage(
&self,
usage: &mut BTreeSet<(QualifiedId<StructId>, FieldId)>
)
Collect field-related operations
sourcepub fn vector_usage(&self, usage: &mut HashSet<Operation>)
pub fn vector_usage(&self, usage: &mut HashSet<Operation>)
Collect vector-related operations
Trait Implementations
impl Eq for ExpData
impl StructuralEq for ExpData
impl StructuralPartialEq for ExpData
Auto Trait Implementations
impl RefUnwindSafe for ExpData
impl !Send for ExpData
impl !Sync for ExpData
impl Unpin for ExpData
impl UnwindSafe for ExpData
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> CallHasher for T where
T: Hash + ?Sized,
impl<T> CallHasher for T where
T: Hash + ?Sized,
sourceimpl<Q, K> Equivalent<K> for Q where
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Q where
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
sourcefn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to key
and return true
if they are equal.
sourceimpl<T> ToOwned for T where
T: Clone,
impl<T> ToOwned for T where
T: Clone,
type Owned = T
type Owned = T
The resulting type after obtaining ownership.
sourcefn clone_into(&self, target: &mut T)
fn clone_into(&self, target: &mut T)
toowned_clone_into
)Uses borrowed data to replace owned data, usually by cloning. Read more