pub type Const = Const<Interner>;
Aliased Type§
struct Const { /* private fields */ }
Implementations
§impl<I> Const<I>where
I: Interner,
impl<I> Const<I>where
I: Interner,
pub fn new(interner: I, data: impl CastTo<ConstData<I>>) -> Const<I>
pub fn new(interner: I, data: impl CastTo<ConstData<I>>) -> Const<I>
Create a Const
using something that can be cast to const data.
pub fn interned(&self) -> &<I as Interner>::InternedConst
pub fn interned(&self) -> &<I as Interner>::InternedConst
Gets the interned constant.
pub fn data(&self, interner: I) -> &ConstData<I>
pub fn data(&self, interner: I) -> &ConstData<I>
Gets the constant data from the interner.
pub fn bound_var(&self, interner: I) -> Option<BoundVar>
pub fn bound_var(&self, interner: I) -> Option<BoundVar>
If this is a ConstData::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 ConstData::InferenceVar(d)
, returns Some(d)
else None
.
pub fn needs_shift(&self, interner: I) -> bool
pub fn needs_shift(&self, interner: I) -> bool
True if this const is a “bound” const, and hence needs to be shifted across binders. Meant for debug assertions.
Trait Implementations§
Source§impl HirDisplay for Const
impl HirDisplay for Const
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,
Returns a
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,
Returns a
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,
Returns a
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,
Returns a
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>
Returns a String representation of
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,
Returns a String representation of
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,
Returns a String representation of
self
that shows the constraint from
the container for functions§impl<I> CastTo<GenericArg<I>> for Const<I>where
I: Interner,
impl<I> CastTo<GenericArg<I>> for Const<I>where
I: Interner,
§impl<I> HasInterner for Const<I>where
I: Interner,
impl<I> HasInterner for Const<I>where
I: Interner,
§impl<I> Ord for Const<I>
impl<I> Ord for Const<I>
§impl<I> PartialOrd for Const<I>where
I: PartialOrd + Interner,
<I as Interner>::InternedConst: PartialOrd,
impl<I> PartialOrd for Const<I>where
I: PartialOrd + Interner,
<I as Interner>::InternedConst: PartialOrd,
§impl<I> TypeFoldable<I> for Const<I>where
I: Interner,
“Folding” a const invokes the fold_const
method on the folder; this
usually (in turn) invokes super_fold_const
to fold the individual
parts.
impl<I> TypeFoldable<I> for Const<I>where
I: Interner,
“Folding” a const invokes the fold_const
method on the folder; this
usually (in turn) invokes super_fold_const
to fold the individual
parts.
§fn try_fold_with<E>(
self,
folder: &mut dyn FallibleTypeFolder<I, Error = E>,
outer_binder: DebruijnIndex,
) -> Result<Const<I>, E>
fn try_fold_with<E>( self, folder: &mut dyn FallibleTypeFolder<I, Error = E>, outer_binder: DebruijnIndex, ) -> Result<Const<I>, E>
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.§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
A convenient alternative to
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 Const<I>where
I: Interner,
impl<I> TypeSuperFoldable<I> for Const<I>where
I: Interner,
§fn try_super_fold_with<E>(
self,
folder: &mut dyn FallibleTypeFolder<I, Error = E>,
outer_binder: DebruijnIndex,
) -> Result<Const<I>, E>
fn try_super_fold_with<E>( self, folder: &mut dyn FallibleTypeFolder<I, Error = E>, outer_binder: DebruijnIndex, ) -> Result<Const<I>, E>
Recursively folds the value.
§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
A convenient alternative to
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 Const<I>where
I: Interner,
impl<I> TypeSuperVisitable<I> for Const<I>where
I: Interner,
§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>
Recursively visits the type contents.
§impl<I> TypeVisitable<I> for Const<I>where
I: Interner,
impl<I> TypeVisitable<I> for Const<I>where
I: Interner,
§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>
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.