Skip to main content

Expr

Enum Expr 

Source
pub enum Expr {
Show 13 variants Var(VarName), Lam { param: VarName, body: Box<Expr>, }, App { func: Box<Expr>, arg: Box<Expr>, }, Let { name: VarName, value: Box<Expr>, body: Box<Expr>, }, Fix { name: VarName, body: Box<Expr>, }, Ref { inner: Box<Expr>, }, Deref { inner: Box<Expr>, }, Assign { target: Box<Expr>, value: Box<Expr>, }, Seq { first: Box<Expr>, second: Box<Expr>, }, Object { entries: Vec<(VarName, Expr)>, prototype: Option<Box<Expr>>, }, Field { object: Box<Expr>, name: VarName, }, Throw { inner: Box<Expr>, }, TryCatch { body: Box<Expr>, catch_param: VarName, handler: Box<Expr>, },
}
Expand description

The abstract syntax tree.

Variants§

§

Var(VarName)

Variable reference.

§

Lam

Lambda abstraction.

Fields

§param: VarName

Bound parameter name.

§body: Box<Expr>

Function body.

§

App

Function application (left-associative at the surface).

Fields

§func: Box<Expr>

The function being applied.

§arg: Box<Expr>

The argument.

§

Let

Let-binding.

Fields

§name: VarName

The bound name.

§value: Box<Expr>

The value being bound.

§body: Box<Expr>

The body in which the binding is in scope.

§

Fix

Fixed-point binding.

Fields

§name: VarName

The name bound to the fixed point inside body.

§body: Box<Expr>

The expression being closed over its own name.

§

Ref

Allocate a fresh cell initialised with the value of inner.

Fields

§inner: Box<Expr>

The expression whose value will populate the new cell.

§

Deref

Dereference the cell pointed to by inner.

Fields

§inner: Box<Expr>

The expression that must evaluate to a Value::Ref.

§

Assign

Assign value into the cell or property pointed to by target. When target is a Expr::Field the assignment is to an own property of the referenced object; otherwise it is to a cell.

Fields

§target: Box<Expr>

The expression denoting the location to be written.

§value: Box<Expr>

The value to store.

§

Seq

Sequence: evaluate first (discarding its value), then evaluate second and return its value.

Fields

§first: Box<Expr>

The expression evaluated for effect only.

§second: Box<Expr>

The expression whose value is the result of the sequence.

§

Object

Object literal with optional prototype. Evaluating an Expr::Object allocates a fresh object on the heap and returns a reference to it.

Fields

§entries: Vec<(VarName, Expr)>

Property entries, in source order. Duplicates resolve by the last write.

§prototype: Option<Box<Expr>>

Optional prototype expression. When Some, the value must evaluate to a reference to another object at run time.

§

Field

Field access on an object. Walks the prototype chain on miss.

Fields

§object: Box<Expr>

The object expression.

§name: VarName

The property name to look up.

§

Throw

Throw an exception carrying the value of inner. Unwinds the current evaluation until caught by an enclosing Expr::TryCatch.

Fields

§inner: Box<Expr>

The value to throw.

§

TryCatch

Catch an exception thrown by body, binding the thrown value to catch_param while evaluating handler.

Fields

§body: Box<Expr>

The expression evaluated under exception protection.

§catch_param: VarName

The name to which a caught thrown value is bound.

§handler: Box<Expr>

The handler expression evaluated when body throws.

Implementations§

Source§

impl Expr

Source

pub fn var(name: impl Into<VarName>) -> Self

Build a variable reference.

Source

pub fn lam(param: impl Into<VarName>, body: Self) -> Self

Build a lambda abstraction.

Source

pub fn app(func: Self, arg: Self) -> Self

Build an application node.

Source

pub fn bind(name: impl Into<VarName>, value: Self, body: Self) -> Self

Build a let-binding. Named bind because let is a keyword.

Source

pub fn fix(name: impl Into<VarName>, body: Self) -> Self

Build a fixed-point binding.

Source

pub fn alloc(inner: Self) -> Self

Build a ref allocation node.

Source

pub fn deref(inner: Self) -> Self

Build a dereference node.

Source

pub fn assign(target: Self, value: Self) -> Self

Build an assignment node.

Source

pub fn seq(first: Self, second: Self) -> Self

Build a sequence node.

Source

pub fn object(entries: Vec<(VarName, Self)>) -> Self

Build an object literal with no prototype.

Source

pub fn object_with_proto(entries: Vec<(VarName, Self)>, prototype: Self) -> Self

Build an object literal with a prototype expression.

Source

pub fn field(object: Self, name: impl Into<VarName>) -> Self

Build a field access node.

Source

pub fn throw(inner: Self) -> Self

Build a throw node.

Source

pub fn try_catch( body: Self, catch_param: impl Into<VarName>, handler: Self, ) -> Self

Build a try-catch node.

Trait Implementations§

Source§

impl Clone for Expr

Source§

fn clone(&self) -> Expr

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for Expr

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Display for Expr

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl PartialEq for Expr

Source§

fn eq(&self, other: &Expr) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 (const: unstable) · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Eq for Expr

Source§

impl StructuralPartialEq for Expr

Auto Trait Implementations§

§

impl Freeze for Expr

§

impl RefUnwindSafe for Expr

§

impl Send for Expr

§

impl Sync for Expr

§

impl Unpin for Expr

§

impl UnsafeUnpin for Expr

§

impl UnwindSafe for Expr

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.