TypeSet

Struct TypeSet 

Source
pub struct TypeSet {
    pub nodes: Vec<TNode>,
    pub subst: Vec<(usize, TypeRef)>,
    pub next_var: usize,
}

Fields§

§nodes: Vec<TNode>§subst: Vec<(usize, TypeRef)>§next_var: usize

Implementations§

Source§

impl TypeSet

Source

pub fn add_tp(&mut self, tp: &Type) -> RawTypeRef

Source

pub fn empty() -> TypeSet

This is the usual way of creating a new Context. The context will be append-only meaning you can roll it back to a point by truncating

Source

pub fn save_state(&self) -> (usize, usize)

Source

pub fn load_state(&mut self, state: (usize, usize))

Source

pub fn might_unify(&self, t1: &RawTypeRef, t2: &TypeRef) -> bool

a very quick non-allocating check that returns false if it’s obvious that these types won’t unify. This works even when a type hasnt been instantiated() to have new type variables. First this checks if t1 and t2 have the same constructors and if theres an obvious mismatch there it gives up. Then it goes and looks up the types in the ctx in case they were typevars, and then again checks if they have th same constructor. It uses apply_immut() to avoid mutating the context for this lookup. Note the apply_immut version of this was wrong bc thats only safe to do on the hole_tp side and apply_immut is already done to the hole before then anyways

Source

pub fn unify(&mut self, t1: &TypeRef, t2: &TypeRef) -> UnifyResult

Normal unification. Does not do the amortizing step of the unionfind (but may mutate it still). See unify_cached() for amortized unionfind. Note that this is likely not slower than unify_cached() in most cases.

Trait Implementations§

Source§

impl Clone for TypeSet

Source§

fn clone(&self) -> TypeSet

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 TypeSet

Source§

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

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

impl PartialEq for TypeSet

Source§

fn eq(&self, other: &TypeSet) -> 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 TypeSet

Source§

impl StructuralPartialEq for TypeSet

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<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
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, 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.