@@ -96,8 +96,14 @@ pub trait HirTyLowerer<'tcx> {
96
96
fn allow_infer ( & self ) -> bool ;
97
97
98
98
/// Returns the region to use when a lifetime is omitted (and not elided).
99
- fn re_infer ( & self , param : Option < & ty:: GenericParamDef > , span : Span )
100
- -> Option < ty:: Region < ' tcx > > ;
99
+ ///
100
+ /// The `borrowed` argument states whether this lifetime is from a reference.
101
+ fn re_infer (
102
+ & self ,
103
+ param : Option < & ty:: GenericParamDef > ,
104
+ span : Span ,
105
+ object_lifetime_default : bool ,
106
+ ) -> ty:: Region < ' tcx > ;
101
107
102
108
/// Returns the type to use when a type is omitted.
103
109
fn ty_infer ( & self , param : Option < & ty:: GenericParamDef > , span : Span ) -> Ty < ' tcx > ;
@@ -294,21 +300,7 @@ impl<'tcx> dyn HirTyLowerer<'tcx> + '_ {
294
300
295
301
Some ( rbv:: ResolvedArg :: Error ( guar) ) => ty:: Region :: new_error ( tcx, guar) ,
296
302
297
- None => {
298
- self . re_infer ( def, lifetime. ident . span ) . unwrap_or_else ( || {
299
- debug ! ( ?lifetime, "unelided lifetime in signature" ) ;
300
-
301
- // This indicates an illegal lifetime
302
- // elision. `resolve_lifetime` should have
303
- // reported an error in this case -- but if
304
- // not, let's error out.
305
- ty:: Region :: new_error_with_message (
306
- tcx,
307
- lifetime. ident . span ,
308
- "unelided lifetime in signature" ,
309
- )
310
- } )
311
- }
303
+ None => self . re_infer ( def, lifetime. ident . span , false ) ,
312
304
}
313
305
}
314
306
@@ -502,20 +494,9 @@ impl<'tcx> dyn HirTyLowerer<'tcx> + '_ {
502
494
) -> ty:: GenericArg < ' tcx > {
503
495
let tcx = self . lowerer . tcx ( ) ;
504
496
match param. kind {
505
- GenericParamDefKind :: Lifetime => self
506
- . lowerer
507
- . re_infer ( Some ( param) , self . span )
508
- . unwrap_or_else ( || {
509
- debug ! ( ?param, "unelided lifetime in signature" ) ;
510
-
511
- // This indicates an illegal lifetime in a non-assoc-trait position
512
- ty:: Region :: new_error_with_message (
513
- tcx,
514
- self . span ,
515
- "unelided lifetime in signature" ,
516
- )
517
- } )
518
- . into ( ) ,
497
+ GenericParamDefKind :: Lifetime => {
498
+ self . lowerer . re_infer ( Some ( param) , self . span , false ) . into ( )
499
+ }
519
500
GenericParamDefKind :: Type { has_default, .. } => {
520
501
if !infer_args && has_default {
521
502
// No type parameter provided, but a default exists.
0 commit comments