Skip to main content

TypeVisitableExt

Trait TypeVisitableExt 

Source
pub trait TypeVisitableExt<I>: TypeVisitable<I>
where I: Interner,
{
Show 28 methods // Required methods fn has_type_flags(&self, flags: TypeFlags) -> bool; fn has_vars_bound_at_or_above(&self, binder: DebruijnIndex) -> bool; fn error_reported(&self) -> Result<(), <I as Interner>::ErrorGuaranteed>; fn non_region_error_reported( &self, ) -> Result<(), <I as Interner>::ErrorGuaranteed>; // Provided methods fn has_vars_bound_above(&self, binder: DebruijnIndex) -> bool { ... } fn has_escaping_bound_vars(&self) -> bool { ... } fn has_aliases(&self) -> bool { ... } fn has_opaque_types(&self) -> bool { ... } fn has_coroutines(&self) -> bool { ... } fn references_error(&self) -> bool { ... } fn has_non_region_param(&self) -> bool { ... } fn has_regions(&self) -> bool { ... } fn has_infer_regions(&self) -> bool { ... } fn has_infer_types(&self) -> bool { ... } fn has_non_region_infer(&self) -> bool { ... } fn has_infer(&self) -> bool { ... } fn has_placeholders(&self) -> bool { ... } fn has_non_region_placeholders(&self) -> bool { ... } fn has_param(&self) -> bool { ... } fn has_free_regions(&self) -> bool { ... } fn has_erased_regions(&self) -> bool { ... } fn has_erasable_regions(&self) -> bool { ... } fn is_global(&self) -> bool { ... } fn has_bound_regions(&self) -> bool { ... } fn has_non_region_bound_vars(&self) -> bool { ... } fn has_bound_vars(&self) -> bool { ... } fn still_further_specializable(&self) -> bool { ... } fn has_non_region_error(&self) -> bool { ... }
}

Required Methods§

Source

fn has_type_flags(&self, flags: TypeFlags) -> bool

Source

fn has_vars_bound_at_or_above(&self, binder: DebruijnIndex) -> bool

Returns true if self has any late-bound regions that are either bound by binder or bound by some binder outside of binder. If binder is ty::INNERMOST, this indicates whether there are any late-bound regions that appear free.

Source

fn error_reported(&self) -> Result<(), <I as Interner>::ErrorGuaranteed>

Source

fn non_region_error_reported( &self, ) -> Result<(), <I as Interner>::ErrorGuaranteed>

Provided Methods§

Source

fn has_vars_bound_above(&self, binder: DebruijnIndex) -> bool

Returns true if this type has any regions that escape binder (and hence are not bound by it).

Source

fn has_escaping_bound_vars(&self) -> bool

Returns true if this type has regions that are not a part of the type. For example, given a for<'a> fn(&'a i32) this function returns false, while given a fn(&'a i32) it returns true. The latter can occur when traversing through the former.

See HasEscapingVarsVisitor for more information.

Source

fn has_aliases(&self) -> bool

Source

fn has_opaque_types(&self) -> bool

Source

fn has_coroutines(&self) -> bool

Source

fn references_error(&self) -> bool

Source

fn has_non_region_param(&self) -> bool

Source

fn has_regions(&self) -> bool

Source

fn has_infer_regions(&self) -> bool

Source

fn has_infer_types(&self) -> bool

Source

fn has_non_region_infer(&self) -> bool

Source

fn has_infer(&self) -> bool

Source

fn has_placeholders(&self) -> bool

Source

fn has_non_region_placeholders(&self) -> bool

Source

fn has_param(&self) -> bool

Source

fn has_free_regions(&self) -> bool

“Free” regions in this context means that it has any region that is not (a) erased or (b) late-bound.

Source

fn has_erased_regions(&self) -> bool

Source

fn has_erasable_regions(&self) -> bool

True if there are any un-erased free regions.

Source

fn is_global(&self) -> bool

Indicates whether this value references only ‘global’ generic parameters that are the same regardless of what fn we are in. This is used for caching.

Source

fn has_bound_regions(&self) -> bool

True if there are any late-bound regions

Source

fn has_non_region_bound_vars(&self) -> bool

True if there are any late-bound non-region variables

Source

fn has_bound_vars(&self) -> bool

True if there are any bound variables

Source

fn still_further_specializable(&self) -> bool

Indicates whether this value still has parameters/placeholders/inference variables which could be replaced later, in a way that would change the results of impl specialization.

Source

fn has_non_region_error(&self) -> bool

True if a type or const error is reachable

Dyn Compatibility§

This trait is not dyn compatible.

In older versions of Rust, dyn compatibility was called "object safety".

Implementors§

Source§

impl<I, T> TypeVisitableExt<I> for T
where I: Interner, T: TypeVisitable<I>,