Skip to main content

Expr

Enum Expr 

Source
pub enum Expr {
    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>,
    },
}
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: fix name. body.

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 pointed to by target.

Fields

§target: Box<Expr>

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

§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.

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. Named alloc to avoid the ref keyword.

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.

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.