@@ -32,13 +32,20 @@ trait ProcessQueryValue<'tcx, T> {
32
32
fn process_decoded ( self , _tcx : TyCtxt < ' tcx > , _err : impl Fn ( ) -> !) -> T ;
33
33
}
34
34
35
- impl < T > ProcessQueryValue < ' _ , Option < T > > for Option < T > {
35
+ impl < T > ProcessQueryValue < ' _ , T > for T {
36
36
#[ inline( always) ]
37
- fn process_decoded ( self , _tcx : TyCtxt < ' _ > , _err : impl Fn ( ) -> !) -> Option < T > {
37
+ fn process_decoded ( self , _tcx : TyCtxt < ' _ > , _err : impl Fn ( ) -> !) -> T {
38
38
self
39
39
}
40
40
}
41
41
42
+ impl < ' tcx , T > ProcessQueryValue < ' tcx , ty:: EarlyBinder < ' tcx , T > > for T {
43
+ #[ inline( always) ]
44
+ fn process_decoded ( self , _tcx : TyCtxt < ' _ > , _err : impl Fn ( ) -> !) -> ty:: EarlyBinder < ' tcx , T > {
45
+ ty:: EarlyBinder :: bind ( self )
46
+ }
47
+ }
48
+
42
49
impl < T > ProcessQueryValue < ' _ , T > for Option < T > {
43
50
#[ inline( always) ]
44
51
fn process_decoded ( self , _tcx : TyCtxt < ' _ > , err : impl Fn ( ) -> !) -> T {
@@ -121,7 +128,12 @@ macro_rules! provide_one {
121
128
provide_one! {
122
129
$tcx, $def_id, $other, $cdata, $name => {
123
130
let lazy = $cdata. root. tables. $name. get( $cdata, $def_id. index) ;
124
- if lazy. is_default( ) { & [ ] } else { $tcx. arena. alloc_from_iter( lazy. decode( ( $cdata, $tcx) ) ) }
131
+ let value = if lazy. is_default( ) {
132
+ & [ ] as & [ _]
133
+ } else {
134
+ $tcx. arena. alloc_from_iter( lazy. decode( ( $cdata, $tcx) ) )
135
+ } ;
136
+ value. process_decoded( $tcx, || panic!( "{:?} does not have a {:?}" , $def_id, stringify!( $name) ) )
125
137
}
126
138
}
127
139
} ;
@@ -230,15 +242,15 @@ impl IntoArgs for (CrateNum, SimplifiedType) {
230
242
}
231
243
232
244
provide ! { tcx, def_id, other, cdata,
233
- explicit_item_bounds => { cdata . get_explicit_item_bounds ( def_id . index , tcx ) }
234
- explicit_item_super_predicates => { cdata . get_explicit_item_super_predicates ( def_id . index , tcx ) }
245
+ explicit_item_bounds => { table_defaulted_array }
246
+ explicit_item_super_predicates => { table_defaulted_array }
235
247
explicit_predicates_of => { table }
236
248
generics_of => { table }
237
249
inferred_outlives_of => { table_defaulted_array }
238
250
explicit_super_predicates_of => { table }
239
251
explicit_implied_predicates_of => { table }
240
252
type_of => { table }
241
- type_alias_is_lazy => { cdata . root . tables . type_alias_is_lazy . get ( cdata , def_id . index ) }
253
+ type_alias_is_lazy => { table_direct }
242
254
variances_of => { table }
243
255
fn_sig => { table }
244
256
codegen_fn_attrs => { table }
@@ -259,7 +271,7 @@ provide! { tcx, def_id, other, cdata,
259
271
lookup_default_body_stability => { table }
260
272
lookup_deprecation_entry => { table }
261
273
params_in_repr => { table }
262
- unused_generic_params => { cdata . root . tables . unused_generic_params . get ( cdata , def_id . index ) }
274
+ unused_generic_params => { table_direct }
263
275
def_kind => { cdata. def_kind( def_id. index) }
264
276
impl_parent => { table }
265
277
defaultness => { table_direct }
@@ -305,9 +317,7 @@ provide! { tcx, def_id, other, cdata,
305
317
. process_decoded( tcx, || panic!( "{def_id:?} does not have trait_impl_trait_tys" ) ) )
306
318
}
307
319
308
- associated_type_for_effects => {
309
- table
310
- }
320
+ associated_type_for_effects => { table }
311
321
associated_types_for_impl_traits_in_associated_fn => { table_defaulted_array }
312
322
313
323
visibility => { cdata. get_visibility( def_id. index) }
@@ -328,7 +338,7 @@ provide! { tcx, def_id, other, cdata,
328
338
item_attrs => { tcx. arena. alloc_from_iter( cdata. get_item_attrs( def_id. index, tcx. sess) ) }
329
339
is_mir_available => { cdata. is_item_mir_available( def_id. index) }
330
340
is_ctfe_mir_available => { cdata. is_ctfe_mir_available( def_id. index) }
331
- cross_crate_inlinable => { cdata . cross_crate_inlinable ( def_id . index ) }
341
+ cross_crate_inlinable => { table_direct }
332
342
333
343
dylib_dependency_formats => { cdata. get_dylib_dependency_formats( tcx) }
334
344
is_private_dep => { cdata. private_dep }
0 commit comments