@@ -158,11 +158,14 @@ enum Scope<'a> {
158158 s : ScopeRef < ' a > ,
159159 } ,
160160
161- /// Resolve the lifetimes in the bounds to the lifetime defs in the generics.
162- /// `fn foo<'a>() -> impl MyTrait<'a> { ... }` desugars to
161+ /// Remap lifetimes that appear in opaque types to fresh lifetime parameters. Given:
162+ /// `fn foo<'a>() -> impl MyTrait<'a> { ... }`
163+ ///
164+ /// HIR tells us that `'a` refer to the lifetime bound on `foo`.
165+ /// However, typeck and borrowck for opaques are work based on using a new generics type.
163166 /// `type MyAnonTy<'b> = impl MyTrait<'b>;`
164- /// ^ ^ this gets resolved in the scope of
165- /// the opaque_ty generics
167+ ///
168+ /// This scope collects the mapping `'a -> 'b`.
166169 Opaque {
167170 /// The opaque type we are traversing.
168171 def_id : LocalDefId ,
@@ -544,11 +547,11 @@ impl<'a, 'tcx> Visitor<'tcx> for BoundVarContext<'a, 'tcx> {
544547 }
545548 }
546549
547- /// Resolve the lifetimes that are applied to the opaque type.
548- /// These are resolved in the current scope .
549- /// `fn foo<'a>() -> impl MyTrait<'a> { ... }` desugars to
550- /// `fn foo<'a>() -> MyAnonTy<'a> { ... }`
551- /// ^ ^this gets resolved in the current scope
550+ /// Resolve the lifetimes inside the opaque type, and save them into
551+ /// `opaque_captured_lifetimes` .
552+ ///
553+ /// This method has special handling for opaques that capture all lifetimes,
554+ /// like async desugaring.
552555 #[ instrument( level = "debug" , skip( self ) ) ]
553556 fn visit_opaque_ty ( & mut self , opaque : & ' tcx rustc_hir:: OpaqueTy < ' tcx > ) {
554557 let mut captures = FxIndexMap :: default ( ) ;
@@ -811,9 +814,6 @@ impl<'a, 'tcx> Visitor<'tcx> for BoundVarContext<'a, 'tcx> {
811814 } ;
812815 self . with ( scope, |this| this. visit_ty ( mt. ty ) ) ;
813816 }
814- hir:: TyKind :: OpaqueDef ( opaque_ty) => {
815- self . visit_opaque_ty ( opaque_ty) ;
816- }
817817 _ => intravisit:: walk_ty ( self , ty) ,
818818 }
819819 }
0 commit comments