Enum chalk_ir::Constraint[][src]

pub enum Constraint<I: Interner> {
    LifetimeOutlives(Lifetime<I>, Lifetime<I>),
    TypeOutlives(Ty<I>, Lifetime<I>),
}
Expand description

A constraint on lifetimes.

When we search for solutions within the trait system, we essentially ignore lifetime constraints, instead gathering them up to return with our solution for later checking. This allows for decoupling between type and region checking in the compiler.

Variants

LifetimeOutlives(Lifetime<I>, Lifetime<I>)

Outlives constraint 'a: 'b, indicating that the value of 'a must be a superset of the value of 'b.

TypeOutlives(Ty<I>, Lifetime<I>)

Type outlives constraint T: 'a, indicating that the type T must live at least as long as the value of 'a.

Trait Implementations

impl<I: Interner> CastTo<Constraint<I>> for Constraint<I>[src]

fn cast_to(
    self,
    _interner: &<Constraint<I> as HasInterner>::Interner
) -> Constraint<I>
[src]

Cast a value to type T.

impl<I: Clone + Interner> Clone for Constraint<I>[src]

fn clone(&self) -> Constraint<I>[src]

Returns a copy of the value. Read more

fn clone_from(&mut self, source: &Self)1.0.0[src]

Performs copy-assignment from source. Read more

impl<I: Interner> Debug for Constraint<I>[src]

fn fmt(&self, fmt: &mut Formatter<'_>) -> Result<(), Error>[src]

Formats the value using the given formatter. Read more

impl<I: Interner> Fold<I> for Constraint<I>[src]

type Result = Constraint<I>

The type of value that will be produced once folding is done. Typically this is Self, unless Self contains borrowed values, in which case owned values are produced (for example, one can fold over a &T value where T: Fold, in which case you get back a T, not a &T). Read more

fn fold_with<'i>(
    self,
    folder: &mut dyn Folder<'i, I>,
    outer_binder: DebruijnIndex
) -> Fallible<Self::Result> where
    I: 'i, 
[src]

Apply the given folder folder to self; binders is the number of binders that are in scope when beginning the folder. Typically binders starts as 0, but is adjusted when we encounter Binders<T> in the IR or other similar constructs. Read more

impl<I: Interner> HasInterner for Constraint<I>[src]

type Interner = I

The interner associated with the type.

impl<I: Hash + Interner> Hash for Constraint<I>[src]

fn hash<__H: Hasher>(&self, state: &mut __H)[src]

Feeds this value into the given Hasher. Read more

fn hash_slice<H>(data: &[Self], state: &mut H) where
    H: Hasher
1.3.0[src]

Feeds a slice of this type into the given Hasher. Read more

impl<I: PartialEq + Interner> PartialEq<Constraint<I>> for Constraint<I>[src]

fn eq(&self, other: &Constraint<I>) -> bool[src]

This method tests for self and other values to be equal, and is used by ==. Read more

fn ne(&self, other: &Constraint<I>) -> bool[src]

This method tests for !=.

impl<I: Interner> Visit<I> for Constraint<I>[src]

fn visit_with<'i, B>(
    &self,
    visitor: &mut dyn Visitor<'i, I, BreakTy = B>,
    outer_binder: DebruijnIndex
) -> ControlFlow<B> where
    I: 'i, 
[src]

Apply the given visitor visitor to self; binders is the number of binders that are in scope when beginning the visitor. Typically binders starts as 0, but is adjusted when we encounter Binders<T> in the IR or other similar constructs. Read more

impl<I: Interner> Zip<I> for Constraint<I>[src]

fn zip_with<'i, Z: Zipper<'i, I>>(
    zipper: &mut Z,
    variance: Variance,
    a: &Self,
    b: &Self
) -> Fallible<()> where
    I: 'i, 
[src]

Uses the zipper to walk through two values, ensuring that they match.

impl<I: Interner> Copy for Constraint<I> where
    I::InternedLifetime: Copy,
    I::InternedType: Copy
[src]

impl<I: Eq + Interner> Eq for Constraint<I>[src]

impl<I: Interner> StructuralEq for Constraint<I>[src]

impl<I: Interner> StructuralPartialEq for Constraint<I>[src]

Auto Trait Implementations

impl<I> RefUnwindSafe for Constraint<I> where
    <I as Interner>::InternedLifetime: RefUnwindSafe,
    <I as Interner>::InternedType: RefUnwindSafe

impl<I> Send for Constraint<I> where
    <I as Interner>::InternedLifetime: Send,
    <I as Interner>::InternedType: Send

impl<I> Sync for Constraint<I> where
    <I as Interner>::InternedLifetime: Sync,
    <I as Interner>::InternedType: Sync

impl<I> Unpin for Constraint<I> where
    <I as Interner>::InternedLifetime: Unpin,
    <I as Interner>::InternedType: Unpin

impl<I> UnwindSafe for Constraint<I> where
    <I as Interner>::InternedLifetime: UnwindSafe,
    <I as Interner>::InternedType: UnwindSafe

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

pub fn type_id(&self) -> TypeId[src]

Gets the TypeId of self. Read more

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

pub fn borrow(&self) -> &T[src]

Immutably borrows from an owned value. Read more

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

pub fn borrow_mut(&mut self) -> &mut T[src]

Mutably borrows from an owned value. Read more

impl<T> Cast for T[src]

fn cast<U>(self, interner: &U::Interner) -> U where
    Self: CastTo<U>,
    U: HasInterner
[src]

Cast a value to type U using CastTo.

impl<T, I> CouldMatch<T> for T where
    T: Zip<I> + HasInterner<Interner = I> + ?Sized,
    I: Interner
[src]

pub fn could_match(&Self, &I, &dyn UnificationDatabase<I>, &T) -> bool[src]

Checks whether self and other could possibly match.

impl<T> From<T> for T[src]

pub fn from(t: T) -> T[src]

Performs the conversion.

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

pub fn into(self) -> U[src]

Performs the conversion.

impl<T, I> Shift<I> for T where
    T: Fold<I>,
    I: Interner
[src]

pub fn shifted_in(Self, &I) -> <T as Fold<I>>::Result[src]

Shifts this term in one level of binders.

pub fn shifted_in_from(Self, &I, DebruijnIndex) -> <T as Fold<I>>::Result[src]

Shifts a term valid at outer_binder so that it is valid at the innermost binder. See DebruijnIndex::shifted_in_from for a detailed explanation. Read more

pub fn shifted_out_to(
    Self,
    &I,
    DebruijnIndex
) -> Result<<T as Fold<I>>::Result, NoSolution>
[src]

Shifts a term valid at the innermost binder so that it is valid at outer_binder. See DebruijnIndex::shifted_out_to for a detailed explanation. Read more

pub fn shifted_out(Self, &I) -> Result<<T as Fold<I>>::Result, NoSolution>[src]

Shifts this term out one level of binders.

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

pub fn to_owned(&self) -> T[src]

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

pub fn clone_into(&self, target: &mut T)[src]

🔬 This is a nightly-only experimental API. (toowned_clone_into)

recently added

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

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

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

Performs the conversion.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

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

The type returned in the event of a conversion error.

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

Performs the conversion.

impl<T, I> VisitExt<I> for T where
    T: Visit<I>,
    I: Interner
[src]

fn has_free_vars(&self, interner: &I) -> bool[src]

Check whether there are free (non-bound) variables.