Struct chalk_ir::Ty [−][src]
pub struct Ty<I: Interner> { /* fields omitted */ }
Expand description
A Rust type. The actual type data is stored in TyKind
.
Implementations
Gets the interned type.
Creates a WF-constraint for this type.
Creates a domain goal FromEnv(T)
where T
is this type.
If this is a TyKind::BoundVar(d)
, returns Some(d)
else None
.
If this is a TyKind::InferenceVar(d)
, returns Some(d)
else None
.
Returns true if this is a BoundVar
or an InferenceVar
of TyVariableKind::General
.
Returns true if this is an IntTy
or UintTy
.
Returns Some(adt_id)
if this is an ADT, None
otherwise
True if this type contains “bound” types/lifetimes, and hence needs to be shifted across binders. This is a very inefficient check, intended only for debug assertions, because I am lazy.
Trait Implementations
Cast a value to type T
.
“Folding” a type invokes the fold_ty
method on the folder; this
usually (in turn) invokes super_fold_ty
to fold the individual
parts.
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
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
type Interner = I
type Interner = I
The interner associated with the type.
This method returns an ordering between self
and other
values if one exists. Read more
This method tests less than (for self
and other
) and is used by the <
operator. Read more
This method tests less than or equal to (for self
and other
) and is used by the <=
operator. Read more
This method tests greater than (for self
and other
) and is used by the >
operator. Read more
“Super fold” for a type invokes te more detailed callbacks on the type
fn super_fold_with<'i>(
self,
folder: &mut dyn Folder<'i, I>,
outer_binder: DebruijnIndex
) -> Fallible<Ty<I>> where
I: 'i,
fn super_fold_with<'i>(
self,
folder: &mut dyn Folder<'i, I>,
outer_binder: DebruijnIndex
) -> Fallible<Ty<I>> where
I: 'i,
Recursively folds the value.
“Super visit” for a type invokes the more detailed callbacks on the type
fn super_visit_with<'i, B>(
&self,
visitor: &mut dyn Visitor<'i, I, BreakTy = B>,
outer_binder: DebruijnIndex
) -> ControlFlow<B> where
I: 'i,
fn super_visit_with<'i, B>(
&self,
visitor: &mut dyn Visitor<'i, I, BreakTy = B>,
outer_binder: DebruijnIndex
) -> ControlFlow<B> where
I: 'i,
Recursively visits the type contents.
“visiting” a type invokes the visit_ty
method on the visitor; this
usually (in turn) invokes super_visit_ty
to visit the individual
parts.
fn visit_with<'i, B>(
&self,
visitor: &mut dyn Visitor<'i, I, BreakTy = B>,
outer_binder: DebruijnIndex
) -> ControlFlow<B> where
I: 'i,
fn visit_with<'i, B>(
&self,
visitor: &mut dyn Visitor<'i, I, BreakTy = B>,
outer_binder: DebruijnIndex
) -> ControlFlow<B> where
I: 'i,
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
Auto Trait Implementations
impl<I> RefUnwindSafe for Ty<I> where
<I as Interner>::InternedType: RefUnwindSafe,
impl<I> Send for Ty<I> where
<I as Interner>::InternedType: Send,
impl<I> Sync for Ty<I> where
<I as Interner>::InternedType: Sync,
impl<I> Unpin for Ty<I> where
<I as Interner>::InternedType: Unpin,
impl<I> UnwindSafe for Ty<I> where
<I as Interner>::InternedType: UnwindSafe,
Blanket Implementations
Mutably borrows from an owned value. Read more
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,
impl<T, I> CouldMatch<T> for T where
T: Zip<I> + HasInterner<Interner = I> + ?Sized,
I: Interner,
Checks whether self
and other
could possibly match.
Shifts this term in one level of binders.
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
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
Shifts this term out one level of binders.