pub type GenericArg = GenericArg<Interner>;
Aliased Type§
struct GenericArg { /* private fields */ }
Implementations
§impl<I> GenericArg<I>where
I: Interner,
impl<I> GenericArg<I>where
I: Interner,
pub fn new(interner: I, data: GenericArgData<I>) -> GenericArg<I>
pub fn new(interner: I, data: GenericArgData<I>) -> GenericArg<I>
Constructs a generic argument using GenericArgData
.
pub fn interned(&self) -> &<I as Interner>::InternedGenericArg
pub fn interned(&self) -> &<I as Interner>::InternedGenericArg
Gets the interned value.
pub fn data(&self, interner: I) -> &GenericArgData<I>
pub fn data(&self, interner: I) -> &GenericArgData<I>
Gets the underlying data.
pub fn assert_ty_ref(&self, interner: I) -> &Ty<I>
pub fn assert_ty_ref(&self, interner: I) -> &Ty<I>
Asserts that this is a type argument.
pub fn assert_lifetime_ref(&self, interner: I) -> &Lifetime<I>
pub fn assert_lifetime_ref(&self, interner: I) -> &Lifetime<I>
Asserts that this is a lifetime argument.
pub fn assert_const_ref(&self, interner: I) -> &Const<I>
pub fn assert_const_ref(&self, interner: I) -> &Const<I>
Asserts that this is a constant argument.
Trait Implementations§
Source§impl HirDisplay for GenericArg
impl HirDisplay for GenericArg
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 GenericArg<I>where
I: Interner,
impl<I> CastTo<GenericArg<I>> for GenericArg<I>where
I: Interner,
§impl<I> HasInterner for GenericArg<I>where
I: Interner,
impl<I> HasInterner for GenericArg<I>where
I: Interner,
§impl<I> Ord for GenericArg<I>
impl<I> Ord for GenericArg<I>
§impl<I> PartialOrd for GenericArg<I>where
I: PartialOrd + Interner,
<I as Interner>::InternedGenericArg: PartialOrd,
impl<I> PartialOrd for GenericArg<I>where
I: PartialOrd + Interner,
<I as Interner>::InternedGenericArg: PartialOrd,
§impl<I> TypeFoldable<I> for GenericArg<I>where
I: Interner,
impl<I> TypeFoldable<I> for GenericArg<I>where
I: Interner,
§fn try_fold_with<E>(
self,
folder: &mut dyn FallibleTypeFolder<I, Error = E>,
outer_binder: DebruijnIndex,
) -> Result<GenericArg<I>, E>
fn try_fold_with<E>( self, folder: &mut dyn FallibleTypeFolder<I, Error = E>, outer_binder: DebruijnIndex, ) -> Result<GenericArg<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> TypeVisitable<I> for GenericArg<I>where
I: Interner,
impl<I> TypeVisitable<I> for GenericArg<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.