Struct chalk_ir::Canonical [−][src]
pub struct Canonical<T: HasInterner> { pub value: T, pub binders: CanonicalVarKinds<T::Interner>, }
Expand description
Wraps a “canonicalized item”. Items are canonicalized as follows:
All unresolved existential variables are “renumbered” according to their
first appearance; the kind/universe of the variable is recorded in the
binders
field.
Fields
value: T
The item that is canonicalized.
binders: CanonicalVarKinds<T::Interner>
The kind/universe of the variable.
Implementations
impl<T: HasInterner + Display> Canonical<T>
[src]
impl<T: HasInterner + Display> Canonical<T>
[src]pub fn display<'a>(
&'a self,
interner: &'a T::Interner
) -> CanonicalDisplay<'a, T>
[src]
pub fn display<'a>(
&'a self,
interner: &'a T::Interner
) -> CanonicalDisplay<'a, T>
[src]Display the canonicalized item.
Trait Implementations
impl<T, U> CastTo<Canonical<U>> for Canonical<T> where
T: CastTo<U> + HasInterner,
U: HasInterner<Interner = T::Interner>,
[src]
impl<T, U> CastTo<Canonical<U>> for Canonical<T> where
T: CastTo<U> + HasInterner,
U: HasInterner<Interner = T::Interner>,
[src]impl<I, T> Fold<I> for Canonical<T> where
I: Interner,
T: HasInterner<Interner = I> + Fold<I>,
<T as Fold<I>>::Result: HasInterner<Interner = I>,
[src]
impl<I, T> Fold<I> for Canonical<T> where
I: Interner,
T: HasInterner<Interner = I> + Fold<I>,
<T as Fold<I>>::Result: HasInterner<Interner = I>,
[src]type Result = Canonical<T::Result>
type Result = Canonical<T::Result>
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]
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<T: HasInterner> HasInterner for Canonical<T>
[src]
impl<T: HasInterner> HasInterner for Canonical<T>
[src]impl<T: PartialEq + HasInterner> PartialEq<Canonical<T>> for Canonical<T> where
T::Interner: PartialEq,
[src]
impl<T: PartialEq + HasInterner> PartialEq<Canonical<T>> for Canonical<T> where
T::Interner: PartialEq,
[src]impl<I, T> Visit<I> for Canonical<T> where
I: Interner,
T: HasInterner<Interner = I> + Visit<I>,
[src]
impl<I, T> Visit<I> for Canonical<T> where
I: Interner,
T: HasInterner<Interner = I> + Visit<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]
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<T: Eq + HasInterner> Eq for Canonical<T> where
T::Interner: Eq,
[src]
T::Interner: Eq,
impl<T: HasInterner> StructuralEq for Canonical<T>
[src]
impl<T: HasInterner> StructuralPartialEq for Canonical<T>
[src]
Auto Trait Implementations
impl<T> RefUnwindSafe for Canonical<T> where
T: RefUnwindSafe,
<<T as HasInterner>::Interner as Interner>::InternedCanonicalVarKinds: RefUnwindSafe,
T: RefUnwindSafe,
<<T as HasInterner>::Interner as Interner>::InternedCanonicalVarKinds: RefUnwindSafe,
impl<T> Send for Canonical<T> where
T: Send,
<<T as HasInterner>::Interner as Interner>::InternedCanonicalVarKinds: Send,
T: Send,
<<T as HasInterner>::Interner as Interner>::InternedCanonicalVarKinds: Send,
impl<T> Sync for Canonical<T> where
T: Sync,
<<T as HasInterner>::Interner as Interner>::InternedCanonicalVarKinds: Sync,
T: Sync,
<<T as HasInterner>::Interner as Interner>::InternedCanonicalVarKinds: Sync,
impl<T> Unpin for Canonical<T> where
T: Unpin,
<<T as HasInterner>::Interner as Interner>::InternedCanonicalVarKinds: Unpin,
T: Unpin,
<<T as HasInterner>::Interner as Interner>::InternedCanonicalVarKinds: Unpin,
impl<T> UnwindSafe for Canonical<T> where
T: UnwindSafe,
<<T as HasInterner>::Interner as Interner>::InternedCanonicalVarKinds: UnwindSafe,
T: UnwindSafe,
<<T as HasInterner>::Interner as Interner>::InternedCanonicalVarKinds: UnwindSafe,
Blanket Implementations
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]pub fn borrow_mut(&mut self) -> &mut T
[src]
pub fn borrow_mut(&mut self) -> &mut T
[src]Mutably borrows from an owned value. Read more
impl<T> Cast for T
[src]
impl<T> Cast for T
[src]fn cast<U>(self, interner: &U::Interner) -> U where
Self: CastTo<U>,
U: HasInterner,
[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> Shift<I> for T where
T: Fold<I>,
I: Interner,
[src]
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]
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]
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]
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]
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]
impl<T> ToOwned for T where
T: Clone,
[src]type Owned = T
type Owned = T
The resulting type after obtaining ownership.
pub fn to_owned(&self) -> T
[src]
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]
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