@@ -46,12 +46,12 @@ use rustc_ast::*;
46
46
use rustc_errors:: ErrorGuaranteed ;
47
47
use rustc_hir:: def_id:: DefId ;
48
48
use rustc_middle:: span_bug;
49
- use rustc_middle:: ty:: { Asyncness , ResolverAstLowering } ;
49
+ use rustc_middle:: ty:: Asyncness ;
50
50
use rustc_span:: { Ident , Span } ;
51
51
use { rustc_ast as ast, rustc_hir as hir} ;
52
52
53
53
use super :: { GenericArgsMode , ImplTraitContext , LoweringContext , ParamMode } ;
54
- use crate :: { AllowReturnTypeNotation , ImplTraitPosition , ResolverAstLoweringExt } ;
54
+ use crate :: { AllowReturnTypeNotation , ImplTraitPosition , PerOwnerResolver } ;
55
55
56
56
pub ( crate ) struct DelegationResults < ' hir > {
57
57
pub body_id : hir:: BodyId ,
@@ -82,6 +82,7 @@ impl<'hir> LoweringContext<'_, 'hir> {
82
82
DefKind :: AssocFn => match def_id. as_local ( ) {
83
83
Some ( local_def_id) => self
84
84
. resolver
85
+ . general
85
86
. delegation_fn_sigs
86
87
. get ( & local_def_id)
87
88
. is_some_and ( |sig| sig. has_self ) ,
@@ -150,7 +151,7 @@ impl<'hir> LoweringContext<'_, 'hir> {
150
151
if let Some ( local_sig_id) = sig_id. as_local ( ) {
151
152
// Map may be filled incorrectly due to recursive delegation.
152
153
// Error will be emitted later during HIR ty lowering.
153
- match self . resolver . delegation_fn_sigs . get ( & local_sig_id) {
154
+ match self . resolver . general . delegation_fn_sigs . get ( & local_sig_id) {
154
155
Some ( sig) => ( sig. param_count , sig. c_variadic ) ,
155
156
None => ( 0 , false ) ,
156
157
}
@@ -198,7 +199,7 @@ impl<'hir> LoweringContext<'_, 'hir> {
198
199
span : Span ,
199
200
) -> hir:: FnSig < ' hir > {
200
201
let header = if let Some ( local_sig_id) = sig_id. as_local ( ) {
201
- match self . resolver . delegation_fn_sigs . get ( & local_sig_id) {
202
+ match self . resolver . general . delegation_fn_sigs . get ( & local_sig_id) {
202
203
Some ( sig) => {
203
204
let parent = self . tcx . parent ( sig_id) ;
204
205
// HACK: we override the default safety instead of generating attributes from the ether.
@@ -280,7 +281,7 @@ impl<'hir> LoweringContext<'_, 'hir> {
280
281
&& idx == 0
281
282
{
282
283
let mut self_resolver = SelfResolver {
283
- resolver : this. resolver ,
284
+ resolver : & mut this. resolver ,
284
285
path_id : delegation. id ,
285
286
self_param_id : pat_node_id,
286
287
} ;
@@ -426,25 +427,25 @@ impl<'hir> LoweringContext<'_, 'hir> {
426
427
}
427
428
}
428
429
429
- struct SelfResolver < ' a > {
430
- resolver : & ' a mut ResolverAstLowering ,
430
+ struct SelfResolver < ' a , ' b > {
431
+ resolver : & ' b mut PerOwnerResolver < ' a > ,
431
432
path_id : NodeId ,
432
433
self_param_id : NodeId ,
433
434
}
434
435
435
- impl < ' a > SelfResolver < ' a > {
436
+ impl SelfResolver < ' _ , ' _ > {
436
437
fn try_replace_id ( & mut self , id : NodeId ) {
437
- if let Some ( res) = self . resolver . partial_res_map . get ( & id)
438
+ if let Some ( res) = self . resolver . general . partial_res_map . get ( & id)
438
439
&& let Some ( Res :: Local ( sig_id) ) = res. full_res ( )
439
440
&& sig_id == self . path_id
440
441
{
441
442
let new_res = PartialRes :: new ( Res :: Local ( self . self_param_id ) ) ;
442
- self . resolver . partial_res_map . insert ( id, new_res) ;
443
+ self . resolver . general . partial_res_map . insert ( id, new_res) ;
443
444
}
444
445
}
445
446
}
446
447
447
- impl < ' ast , ' a > Visitor < ' ast > for SelfResolver < ' a > {
448
+ impl < ' ast > Visitor < ' ast > for SelfResolver < ' _ , ' _ > {
448
449
fn visit_path ( & mut self , path : & ' ast Path , id : NodeId ) {
449
450
self . try_replace_id ( id) ;
450
451
visit:: walk_path ( self , path) ;
0 commit comments