pub type Ty = Ty<Interner>;
Aliased Type§
struct Ty { /* private fields */ }
Implementations
§impl<I> Ty<I>where
I: Interner,
impl<I> Ty<I>where
I: Interner,
pub fn new(interner: I, data: impl CastTo<TyKind<I>>) -> Ty<I>
pub fn new(interner: I, data: impl CastTo<TyKind<I>>) -> Ty<I>
Creates a type from TyKind
.
pub fn interned(&self) -> &<I as Interner>::InternedType
pub fn interned(&self) -> &<I as Interner>::InternedType
Gets the interned type.
pub fn data(&self, interner: I) -> &TyData<I>
pub fn data(&self, interner: I) -> &TyData<I>
Gets the underlying type data.
pub fn kind(&self, interner: I) -> &TyKind<I>
pub fn kind(&self, interner: I) -> &TyKind<I>
Gets the underlying type kind.
pub fn from_env(&self) -> FromEnv<I>
pub fn from_env(&self) -> FromEnv<I>
Creates a FromEnv
constraint using this type.
pub fn well_formed(&self) -> WellFormed<I>
pub fn well_formed(&self) -> WellFormed<I>
Creates a WF-constraint for this type.
pub fn into_from_env_goal(self, interner: I) -> DomainGoal<I>
pub fn into_from_env_goal(self, interner: I) -> DomainGoal<I>
Creates a domain goal FromEnv(T)
where T
is this type.
pub fn bound_var(&self, interner: I) -> Option<BoundVar>
pub fn bound_var(&self, interner: I) -> Option<BoundVar>
If this is a TyKind::BoundVar(d)
, returns Some(d)
else None
.
pub fn inference_var(&self, interner: I) -> Option<InferenceVar>
pub fn inference_var(&self, interner: I) -> Option<InferenceVar>
If this is a TyKind::InferenceVar(d)
, returns Some(d)
else None
.
pub fn is_general_var(
&self,
interner: I,
binders: &CanonicalVarKinds<I>,
) -> bool
pub fn is_general_var( &self, interner: I, binders: &CanonicalVarKinds<I>, ) -> bool
Returns true if this is a BoundVar
or an InferenceVar
of TyVariableKind::General
.
pub fn is_integer(&self, interner: I) -> bool
pub fn is_integer(&self, interner: I) -> bool
Returns true if this is an IntTy
or UintTy
.
pub fn adt_id(&self, interner: I) -> Option<AdtId<I>>
pub fn adt_id(&self, interner: I) -> Option<AdtId<I>>
Returns Some(adt_id)
if this is an ADT, None
otherwise
pub fn needs_shift(&self, interner: I) -> bool
pub fn needs_shift(&self, interner: I) -> bool
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§
Source§impl HirDisplay for Ty
impl HirDisplay for Ty
fn hir_fmt(&self, f: &mut HirFormatter<'_>) -> Result<(), HirDisplayError>
Source§fn into_displayable<'a>(
&'a self,
db: &'a dyn HirDatabase,
max_size: Option<usize>,
limited_size: Option<usize>,
omit_verbose_types: bool,
display_target: DisplayTarget,
display_kind: DisplayKind,
closure_style: ClosureStyle,
show_container_bounds: bool,
) -> HirDisplayWrapper<'a, Self>where
Self: Sized,
fn into_displayable<'a>(
&'a self,
db: &'a dyn HirDatabase,
max_size: Option<usize>,
limited_size: Option<usize>,
omit_verbose_types: bool,
display_target: DisplayTarget,
display_kind: DisplayKind,
closure_style: ClosureStyle,
show_container_bounds: bool,
) -> HirDisplayWrapper<'a, Self>where
Self: Sized,
Display
able type that is human-readable.Source§fn display<'a>(
&'a self,
db: &'a dyn HirDatabase,
display_target: DisplayTarget,
) -> HirDisplayWrapper<'a, Self>where
Self: Sized,
fn display<'a>(
&'a self,
db: &'a dyn HirDatabase,
display_target: DisplayTarget,
) -> HirDisplayWrapper<'a, Self>where
Self: Sized,
Display
able type that is human-readable.
Use this for showing types to the user (e.g. diagnostics)Source§fn display_truncated<'a>(
&'a self,
db: &'a dyn HirDatabase,
max_size: Option<usize>,
display_target: DisplayTarget,
) -> HirDisplayWrapper<'a, Self>where
Self: Sized,
fn display_truncated<'a>(
&'a self,
db: &'a dyn HirDatabase,
max_size: Option<usize>,
display_target: DisplayTarget,
) -> HirDisplayWrapper<'a, Self>where
Self: Sized,
Display
able type that is human-readable and tries to be succinct.
Use this for showing types to the user where space is constrained (e.g. doc popups)Source§fn display_limited<'a>(
&'a self,
db: &'a dyn HirDatabase,
limited_size: Option<usize>,
display_target: DisplayTarget,
) -> HirDisplayWrapper<'a, Self>where
Self: Sized,
fn display_limited<'a>(
&'a self,
db: &'a dyn HirDatabase,
limited_size: Option<usize>,
display_target: DisplayTarget,
) -> HirDisplayWrapper<'a, Self>where
Self: Sized,
Display
able type that is human-readable and tries to limit the number of items inside.
Use this for showing definitions which may contain too many items, like trait
, struct
, enum
Source§fn display_source_code<'a>(
&'a self,
db: &'a dyn HirDatabase,
module_id: ModuleId,
allow_opaque: bool,
) -> Result<String, DisplaySourceCodeError>
fn display_source_code<'a>( &'a self, db: &'a dyn HirDatabase, module_id: ModuleId, allow_opaque: bool, ) -> Result<String, DisplaySourceCodeError>
self
that can be inserted into the given module.
Use this when generating code (e.g. assists)Source§fn display_test<'a>(
&'a self,
db: &'a dyn HirDatabase,
display_target: DisplayTarget,
) -> HirDisplayWrapper<'a, Self>where
Self: Sized,
fn display_test<'a>(
&'a self,
db: &'a dyn HirDatabase,
display_target: DisplayTarget,
) -> HirDisplayWrapper<'a, Self>where
Self: Sized,
self
for test purposesSource§fn display_with_container_bounds<'a>(
&'a self,
db: &'a dyn HirDatabase,
show_container_bounds: bool,
display_target: DisplayTarget,
) -> HirDisplayWrapper<'a, Self>where
Self: Sized,
fn display_with_container_bounds<'a>(
&'a self,
db: &'a dyn HirDatabase,
show_container_bounds: bool,
display_target: DisplayTarget,
) -> HirDisplayWrapper<'a, Self>where
Self: Sized,
self
that shows the constraint from
the container for functionsSource§impl TyExt for Ty
impl TyExt for Ty
fn is_unit(&self) -> bool
fn is_integral(&self) -> bool
fn is_scalar(&self) -> bool
fn is_floating_point(&self) -> bool
fn is_never(&self) -> bool
fn is_str(&self) -> bool
fn is_unknown(&self) -> bool
fn contains_unknown(&self) -> bool
fn is_ty_var(&self) -> bool
fn is_union(&self) -> bool
fn as_adt(&self) -> Option<(AdtId, &Substitution)>
fn as_builtin(&self) -> Option<BuiltinType>
fn as_tuple(&self) -> Option<&Substitution>
fn as_closure(&self) -> Option<ClosureId>
fn as_fn_def(&self, db: &dyn HirDatabase) -> Option<FunctionId>
fn as_reference(&self) -> Option<(&Ty, Lifetime, Mutability)>
fn as_raw_ptr(&self) -> Option<(&Ty, Mutability)>
fn as_reference_or_ptr(&self) -> Option<(&Ty, Rawness, Mutability)>
fn as_generic_def(&self, db: &dyn HirDatabase) -> Option<GenericDefId>
fn callable_def(&self, db: &dyn HirDatabase) -> Option<CallableDefId>
fn callable_sig(&self, db: &dyn HirDatabase) -> Option<CallableSig>
fn strip_references(&self) -> &Ty
fn strip_reference(&self) -> &Ty
fn impl_trait_bounds( &self, db: &dyn HirDatabase, ) -> Option<Vec<QuantifiedWhereClause>>
fn associated_type_parent_trait(&self, db: &dyn HirDatabase) -> Option<TraitId>
fn is_copy(self, db: &dyn HirDatabase, owner: DefWithBodyId) -> bool
Source§fn equals_ctor(&self, other: &Ty) -> bool
fn equals_ctor(&self, other: &Ty) -> bool
§impl<I> CastTo<GenericArg<I>> for Ty<I>where
I: Interner,
impl<I> CastTo<GenericArg<I>> for Ty<I>where
I: Interner,
§impl<I> HasInterner for Ty<I>where
I: Interner,
impl<I> HasInterner for Ty<I>where
I: Interner,
§impl<I> Ord for Ty<I>
impl<I> Ord for Ty<I>
§impl<I> PartialOrd for Ty<I>where
I: PartialOrd + Interner,
<I as Interner>::InternedType: PartialOrd,
impl<I> PartialOrd for Ty<I>where
I: PartialOrd + Interner,
<I as Interner>::InternedType: PartialOrd,
§impl<I> TypeFoldable<I> for Ty<I>where
I: Interner,
“Folding” a type invokes the try_fold_ty
method on the folder; this
usually (in turn) invokes try_super_fold_ty
to fold the individual
parts.
impl<I> TypeFoldable<I> for Ty<I>where
I: Interner,
“Folding” a type invokes the try_fold_ty
method on the folder; this
usually (in turn) invokes try_super_fold_ty
to fold the individual
parts.
§fn try_fold_with<E>(
self,
folder: &mut dyn FallibleTypeFolder<I, Error = E>,
outer_binder: DebruijnIndex,
) -> Result<Ty<I>, E>
fn try_fold_with<E>( self, folder: &mut dyn FallibleTypeFolder<I, Error = E>, outer_binder: DebruijnIndex, ) -> Result<Ty<I>, E>
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.§fn fold_with(
self,
folder: &mut dyn TypeFolder<I, Error = Infallible>,
outer_binder: DebruijnIndex,
) -> Self
fn fold_with( self, folder: &mut dyn TypeFolder<I, Error = Infallible>, outer_binder: DebruijnIndex, ) -> Self
try_fold_with
for use with infallible
folders. Do not override this method, to ensure coherence with
try_fold_with
.§impl<I> TypeSuperFoldable<I> for Ty<I>where
I: Interner,
“Super fold” for a type invokes te more detailed callbacks on the type
impl<I> TypeSuperFoldable<I> for Ty<I>where
I: Interner,
“Super fold” for a type invokes te more detailed callbacks on the type
§fn try_super_fold_with<E>(
self,
folder: &mut dyn FallibleTypeFolder<I, Error = E>,
outer_binder: DebruijnIndex,
) -> Result<Ty<I>, E>
fn try_super_fold_with<E>( self, folder: &mut dyn FallibleTypeFolder<I, Error = E>, outer_binder: DebruijnIndex, ) -> Result<Ty<I>, E>
§fn super_fold_with(
self,
folder: &mut dyn TypeFolder<I, Error = Infallible>,
outer_binder: DebruijnIndex,
) -> Self
fn super_fold_with( self, folder: &mut dyn TypeFolder<I, Error = Infallible>, outer_binder: DebruijnIndex, ) -> Self
try_super_fold_with
for use with
infallible folders. Do not override this method, to ensure coherence
with try_super_fold_with
.§impl<I> TypeSuperVisitable<I> for Ty<I>where
I: Interner,
“Super visit” for a type invokes the more detailed callbacks on the type
impl<I> TypeSuperVisitable<I> for Ty<I>where
I: Interner,
“Super visit” for a type invokes the more detailed callbacks on the type
§fn super_visit_with<B>(
&self,
visitor: &mut dyn TypeVisitor<I, BreakTy = B>,
outer_binder: DebruijnIndex,
) -> ControlFlow<B>
fn super_visit_with<B>( &self, visitor: &mut dyn TypeVisitor<I, BreakTy = B>, outer_binder: DebruijnIndex, ) -> ControlFlow<B>
§impl<I> TypeVisitable<I> for Ty<I>where
I: Interner,
“visiting” a type invokes the visit_ty
method on the visitor; this
usually (in turn) invokes super_visit_ty
to visit the individual
parts.
impl<I> TypeVisitable<I> for Ty<I>where
I: Interner,
“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<B>(
&self,
visitor: &mut dyn TypeVisitor<I, BreakTy = B>,
outer_binder: DebruijnIndex,
) -> ControlFlow<B>
fn visit_with<B>( &self, visitor: &mut dyn TypeVisitor<I, BreakTy = B>, outer_binder: DebruijnIndex, ) -> ControlFlow<B>
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.