rustc_hir_analysis::collect::resolve_bound_vars

Struct BoundVarContext

Source
struct BoundVarContext<'a, 'tcx> {
    tcx: TyCtxt<'tcx>,
    map: &'a mut NamedVarMap,
    scope: &'a Scope<'a>,
}

Fields§

§tcx: TyCtxt<'tcx>§map: &'a mut NamedVarMap§scope: &'a Scope<'a>

Implementations§

Source§

impl<'a, 'tcx> BoundVarContext<'a, 'tcx>

Source

fn poly_trait_ref_binder_info( &mut self, ) -> (Vec<BoundVariableKind>, BinderScopeType)

Returns the binders in scope and the type of Binder that should be created for a poly trait ref.

Source

fn visit_poly_trait_ref_inner( &mut self, trait_ref: &'tcx PolyTraitRef<'tcx>, non_lifetime_binder_allowed: NonLifetimeBinderAllowed, )

Source§

impl<'a, 'tcx> BoundVarContext<'a, 'tcx>

Source

fn with<F>(&mut self, wrap_scope: Scope<'_>, f: F)
where F: for<'b> FnOnce(&mut BoundVarContext<'b, 'tcx>),

Source

fn record_late_bound_vars( &mut self, hir_id: HirId, binder: Vec<BoundVariableKind>, )

Source

fn visit_early_late<F>( &mut self, hir_id: HirId, generics: &'tcx Generics<'tcx>, walk: F, )
where F: for<'b, 'c> FnOnce(&'b mut BoundVarContext<'c, 'tcx>),

Visits self by adding a scope and handling recursive walk over the contents with walk.

Handles visiting fns and methods. These are a bit complicated because we must distinguish early- vs late-bound lifetime parameters. We do this by checking which lifetimes appear within type bounds; those are early bound lifetimes, and the rest are late bound.

For example:

fn foo<’a,’b,’c,T:Trait<’b>>(…)

Here 'a and 'c are late bound but 'b is early bound. Note that early- and late-bound lifetimes may be interspersed together.

If early bound lifetimes are present, we separate them into their own list (and likewise for late bound). They will be numbered sequentially, starting from the lowest index that is already in scope (for a fn item, that will be 0, but for a method it might not be). Late bound lifetimes are resolved by name and associated with a binder ID (binder_id), so the ordering is not important there.

Source

fn visit_early<F>( &mut self, hir_id: HirId, generics: &'tcx Generics<'tcx>, walk: F, )
where F: for<'b, 'c> FnOnce(&'b mut BoundVarContext<'c, 'tcx>),

Source

fn resolve_lifetime_ref( &mut self, region_def_id: LocalDefId, lifetime_ref: &'tcx Lifetime, )

Source

fn check_lifetime_is_capturable( &self, opaque_def_id: LocalDefId, lifetime: ResolvedArg, capture_span: Span, ) -> Result<(), ErrorGuaranteed>

Check for predicates like impl for<'a> Trait<impl OtherTrait<'a>> and ban them. Type variables instantiated inside binders aren’t well-supported at the moment, so this doesn’t work. In the future, this should be fixed and this error should be removed.

Source

fn remap_opaque_captures( &self, opaque_capture_scopes: &Vec<(LocalDefId, &RefCell<FxIndexMap<ResolvedArg, LocalDefId>>)>, lifetime: ResolvedArg, ident: Ident, ) -> ResolvedArg

Source

fn resolve_type_ref(&mut self, param_def_id: LocalDefId, hir_id: HirId)

Source

fn visit_segment_args( &mut self, res: Res, depth: usize, generic_args: &'tcx GenericArgs<'tcx>, )

Source

fn supertrait_hrtb_vars( tcx: TyCtxt<'tcx>, def_id: DefId, assoc_name: Ident, assoc_kind: AssocKind, ) -> Option<(Vec<BoundVariableKind>, &'tcx AssocItem)>

Returns all the late-bound vars that come into scope from supertrait HRTBs, based on the associated type name and starting trait. For example, imagine we have

trait Foo<'a, 'b> {
  type As;
}
trait Bar<'b>: for<'a> Foo<'a, 'b> {}
trait Bar: for<'b> Bar<'b> {}

In this case, if we wanted to the supertrait HRTB lifetimes for As on the starting trait Bar, we would return Some(['b, 'a]).

Source

fn visit_fn_like_elision( &mut self, inputs: &'tcx [Ty<'tcx>], output: Option<&'tcx Ty<'tcx>>, in_closure: bool, )

Source

fn resolve_object_lifetime_default(&mut self, lifetime_ref: &'tcx Lifetime)

Source

fn insert_lifetime(&mut self, lifetime_ref: &'tcx Lifetime, def: ResolvedArg)

Source

fn try_append_return_type_notation_params( &mut self, hir_id: HirId, hir_ty: &'tcx Ty<'tcx>, )

Source

fn for_each_trait_bound_on_res( &self, expected_res: Res, ) -> impl Iterator<Item = DefId> + use<'tcx, '_>

Walk the generics of the item for a trait bound whose self type corresponds to the expected res, and return the trait def id.

Trait Implementations§

Source§

impl<'a, 'tcx> Visitor<'tcx> for BoundVarContext<'a, 'tcx>

Source§

fn visit_opaque_ty(&mut self, opaque: &'tcx OpaqueTy<'tcx>)

Resolve the lifetimes inside the opaque type, and save them into opaque_captured_lifetimes.

This method has special handling for opaques that capture all lifetimes, like async desugaring.

Source§

type NestedFilter = OnlyBodies

Override this type to control which nested HIR are visited; see NestedFilter for details. If you override this type, you must also override nested_visit_map. Read more
Source§

fn nested_visit_map(&mut self) -> Self::Map

If type NestedFilter is set to visit nested items, this method must also be overridden to provide a map to retrieve nested items.
Source§

fn visit_nested_body(&mut self, body: BodyId)

Invoked to visit the body of a function, method or closure. Like visit_nested_item, does nothing by default unless you override Self::NestedFilter.
Source§

fn visit_expr(&mut self, e: &'tcx Expr<'tcx>)

Source§

fn visit_item(&mut self, item: &'tcx Item<'tcx>)

Visits the top-level item and (optionally) nested items / impl items. See visit_nested_item for details.
Source§

fn visit_precise_capturing_arg( &mut self, arg: &'tcx PreciseCapturingArg<'tcx>, ) -> Self::Result

Source§

fn visit_foreign_item(&mut self, item: &'tcx ForeignItem<'tcx>)

Source§

fn visit_ty(&mut self, ty: &'tcx Ty<'tcx>)

Source§

fn visit_pattern_type_pattern(&mut self, p: &'tcx Pat<'tcx>)

Source§

fn visit_trait_item(&mut self, trait_item: &'tcx TraitItem<'tcx>)

Source§

fn visit_impl_item(&mut self, impl_item: &'tcx ImplItem<'tcx>)

Source§

fn visit_lifetime(&mut self, lifetime_ref: &'tcx Lifetime)

Source§

fn visit_path(&mut self, path: &Path<'tcx>, hir_id: HirId)

Source§

fn visit_fn( &mut self, fk: FnKind<'tcx>, fd: &'tcx FnDecl<'tcx>, body_id: BodyId, _: Span, def_id: LocalDefId, )

Source§

fn visit_generics(&mut self, generics: &'tcx Generics<'tcx>)

Source§

fn visit_where_predicate(&mut self, predicate: &'tcx WherePredicate<'tcx>)

Source§

fn visit_poly_trait_ref(&mut self, trait_ref: &'tcx PolyTraitRef<'tcx>)

Source§

fn visit_anon_const(&mut self, c: &'tcx AnonConst)

Source§

fn visit_generic_param(&mut self, p: &'tcx GenericParam<'tcx>)

Source§

type Map = <Self::NestedFilter as NestedFilter<'v>>::Map

Source§

type Result = ()

The result type of the visit_* methods. Can be either (), or ControlFlow<T>.
Source§

fn visit_nested_item(&mut self, id: ItemId) -> Self::Result

Invoked when a nested item is encountered. By default, when Self::NestedFilter is nested_filter::None, this method does nothing. You probably don’t want to override this method – instead, override Self::NestedFilter or use the “shallow” or “deep” visit patterns described at rustc_hir::intravisit. The only reason to override this method is if you want a nested pattern but cannot supply a Map; see nested_visit_map for advice.
Source§

fn visit_nested_trait_item(&mut self, id: TraitItemId) -> Self::Result

Like visit_nested_item(), but for trait items. See visit_nested_item() for advice on when to override this method.
Source§

fn visit_nested_impl_item(&mut self, id: ImplItemId) -> Self::Result

Like visit_nested_item(), but for impl items. See visit_nested_item() for advice on when to override this method.
Source§

fn visit_nested_foreign_item(&mut self, id: ForeignItemId) -> Self::Result

Like visit_nested_item(), but for foreign items. See visit_nested_item() for advice on when to override this method.
Source§

fn visit_param(&mut self, param: &'v Param<'v>) -> Self::Result

Source§

fn visit_body(&mut self, b: &Body<'v>) -> Self::Result

Source§

fn visit_id(&mut self, _hir_id: HirId) -> Self::Result

Source§

fn visit_name(&mut self, _name: Symbol) -> Self::Result

Source§

fn visit_ident(&mut self, ident: Ident) -> Self::Result

Source§

fn visit_mod(&mut self, m: &'v Mod<'v>, _s: Span, n: HirId) -> Self::Result

Source§

fn visit_local(&mut self, l: &'v LetStmt<'v>) -> Self::Result

Source§

fn visit_block(&mut self, b: &'v Block<'v>) -> Self::Result

Source§

fn visit_stmt(&mut self, s: &'v Stmt<'v>) -> Self::Result

Source§

fn visit_arm(&mut self, a: &'v Arm<'v>) -> Self::Result

Source§

fn visit_pat(&mut self, p: &'v Pat<'v>) -> Self::Result

Source§

fn visit_pat_field(&mut self, f: &'v PatField<'v>) -> Self::Result

Source§

fn visit_inline_const(&mut self, c: &'v ConstBlock) -> Self::Result

Source§

fn visit_const_arg(&mut self, c: &'v ConstArg<'v>) -> Self::Result

Source§

fn visit_expr_field(&mut self, field: &'v ExprField<'v>) -> Self::Result

Source§

fn visit_const_param_default( &mut self, _param: HirId, ct: &'v ConstArg<'v>, ) -> Self::Result

Source§

fn visit_fn_ret_ty(&mut self, ret_ty: &'v FnRetTy<'v>) -> Self::Result

Source§

fn visit_fn_decl(&mut self, fd: &'v FnDecl<'v>) -> Self::Result

Source§

fn visit_use( &mut self, path: &'v Path<'v, SmallVec<[Res; 3]>>, hir_id: HirId, ) -> Self::Result

Source§

fn visit_trait_item_ref(&mut self, ii: &'v TraitItemRef) -> Self::Result

Source§

fn visit_foreign_item_ref(&mut self, ii: &'v ForeignItemRef) -> Self::Result

Source§

fn visit_impl_item_ref(&mut self, ii: &'v ImplItemRef) -> Self::Result

Source§

fn visit_trait_ref(&mut self, t: &'v TraitRef<'v>) -> Self::Result

Source§

fn visit_param_bound(&mut self, bounds: &'v GenericBound<'v>) -> Self::Result

Source§

fn visit_variant_data(&mut self, s: &'v VariantData<'v>) -> Self::Result

Source§

fn visit_field_def(&mut self, s: &'v FieldDef<'v>) -> Self::Result

Source§

fn visit_enum_def( &mut self, enum_definition: &'v EnumDef<'v>, item_id: HirId, ) -> Self::Result

Source§

fn visit_variant(&mut self, v: &'v Variant<'v>) -> Self::Result

Source§

fn visit_label(&mut self, label: &'v Label) -> Self::Result

Source§

fn visit_infer(&mut self, inf: &'v InferArg) -> Self::Result

Source§

fn visit_generic_arg(&mut self, generic_arg: &'v GenericArg<'v>) -> Self::Result

Source§

fn visit_qpath( &mut self, qpath: &'v QPath<'v>, id: HirId, _span: Span, ) -> Self::Result

Source§

fn visit_path_segment( &mut self, path_segment: &'v PathSegment<'v>, ) -> Self::Result

Source§

fn visit_generic_args( &mut self, generic_args: &'v GenericArgs<'v>, ) -> Self::Result

Source§

fn visit_assoc_item_constraint( &mut self, constraint: &'v AssocItemConstraint<'v>, ) -> Self::Result

Source§

fn visit_attribute(&mut self, _attr: &'v Attribute) -> Self::Result

Source§

fn visit_associated_item_kind( &mut self, kind: &'v AssocItemKind, ) -> Self::Result

Source§

fn visit_defaultness(&mut self, defaultness: &'v Defaultness) -> Self::Result

Source§

fn visit_inline_asm( &mut self, asm: &'v InlineAsm<'v>, id: HirId, ) -> Self::Result

Auto Trait Implementations§

§

impl<'a, 'tcx> !DynSend for BoundVarContext<'a, 'tcx>

§

impl<'a, 'tcx> !DynSync for BoundVarContext<'a, 'tcx>

§

impl<'a, 'tcx> Freeze for BoundVarContext<'a, 'tcx>

§

impl<'a, 'tcx> !RefUnwindSafe for BoundVarContext<'a, 'tcx>

§

impl<'a, 'tcx> !Send for BoundVarContext<'a, 'tcx>

§

impl<'a, 'tcx> !Sync for BoundVarContext<'a, 'tcx>

§

impl<'a, 'tcx> Unpin for BoundVarContext<'a, 'tcx>

§

impl<'a, 'tcx> !UnwindSafe for BoundVarContext<'a, 'tcx>

Blanket Implementations§

Source§

impl<T> Aligned for T

Source§

const ALIGN: Alignment

Alignment of Self.
Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T, R> CollectAndApply<T, R> for T

Source§

fn collect_and_apply<I, F>(iter: I, f: F) -> R
where I: Iterator<Item = T>, F: FnOnce(&[T]) -> R,

Equivalent to f(&iter.collect::<Vec<_>>()).

Source§

type Output = R

Source§

impl<T> Filterable for T

Source§

fn filterable( self, filter_name: &'static str, ) -> RequestFilterDataProvider<T, fn(_: DataRequest<'_>) -> bool>

Creates a filterable data provider with the given name for debugging. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<P> IntoQueryParam<P> for P

Source§

impl<T> MaybeResult<T> for T

Source§

type Error = !

Source§

fn from(_: Result<T, <T as MaybeResult<T>>::Error>) -> T

Source§

fn to_result(self) -> Result<T, <T as MaybeResult<T>>::Error>

Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<I, T, U> Upcast<I, U> for T
where U: UpcastFrom<I, T>,

Source§

fn upcast(self, interner: I) -> U

Source§

impl<I, T> UpcastFrom<I, T> for T

Source§

fn upcast_from(from: T, _tcx: I) -> T

Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<Tcx, T> Value<Tcx> for T
where Tcx: DepContext,

Source§

default fn from_cycle_error( tcx: Tcx, cycle_error: &CycleError, _guar: ErrorGuaranteed, ) -> T

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<'a, T> Captures<'a> for T
where T: ?Sized,

Source§

impl<T> ErasedDestructor for T
where T: 'static,

Layout§

Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.

Size: 24 bytes