Skip to main content

ProofStep

Enum ProofStep 

Source
pub enum ProofStep {
    Beta {
        redex_depth: u32,
    },
    Delta {
        name: String,
    },
    Zeta,
    Iota {
        recursor: String,
        ctor_idx: u32,
    },
    Eta,
    SubstLevel {
        params: Vec<String>,
    },
    Assumption,
}
Expand description

A single step in a proof reduction sequence.

These steps record the high-level reduction moves taken during kernel type-checking, enabling efficient replay or auditing.

Variants§

§

Beta

β-reduction: substitute the argument into the body.

redex_depth records the nesting depth at which this reduction occurred.

Fields

§redex_depth: u32

De Bruijn depth of the beta-redex site.

§

Delta

δ-reduction: unfold a named definition.

Fields

§name: String

Name of the definition that was unfolded.

§

Zeta

ζ-reduction: substitute a let-binding.

§

Iota

ι-reduction: reduce a recursor application to a branch.

Fields

§recursor: String

Name of the recursor that fired.

§ctor_idx: u32

Index of the constructor branch selected.

§

Eta

η-reduction: contract λ x, f x to f.

§

SubstLevel

Universe-level substitution.

Fields

§params: Vec<String>

Parameter names substituted.

§

Assumption

Appeal to a local assumption (hypothesis) in the context.

Trait Implementations§

Source§

impl Clone for ProofStep

Source§

fn clone(&self) -> ProofStep

Returns a duplicate of the value. Read more
1.0.0 · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for ProofStep

Source§

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

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

impl Display for ProofStep

Source§

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

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

impl PartialEq for ProofStep

Source§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0 · 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 ProofStep

Source§

impl StructuralPartialEq for ProofStep

Auto Trait Implementations§

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.