@@ -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 {
@@ -103,7 +110,12 @@ macro_rules! provide_one {
103
110
provide_one! {
104
111
$tcx, $def_id, $other, $cdata, $name => {
105
112
let lazy = $cdata. root. tables. $name. get( $cdata, $def_id. index) ;
106
- if lazy. is_default( ) { & [ ] } else { $tcx. arena. alloc_from_iter( lazy. decode( ( $cdata, $tcx) ) ) }
113
+ let value = if lazy. is_default( ) {
114
+ & [ ] as & [ _]
115
+ } else {
116
+ $tcx. arena. alloc_from_iter( lazy. decode( ( $cdata, $tcx) ) )
117
+ } ;
118
+ value. process_decoded( $tcx, || panic!( "{:?} does not have a {:?}" , $def_id, stringify!( $name) ) )
107
119
}
108
120
}
109
121
} ;
@@ -212,15 +224,15 @@ impl IntoArgs for (CrateNum, SimplifiedType) {
212
224
}
213
225
214
226
provide ! { tcx, def_id, other, cdata,
215
- explicit_item_bounds => { cdata . get_explicit_item_bounds ( def_id . index , tcx ) }
216
- explicit_item_super_predicates => { cdata . get_explicit_item_super_predicates ( def_id . index , tcx ) }
227
+ explicit_item_bounds => { table_defaulted_array }
228
+ explicit_item_super_predicates => { table_defaulted_array }
217
229
explicit_predicates_of => { table }
218
230
generics_of => { table }
219
231
inferred_outlives_of => { table_defaulted_array }
220
232
explicit_super_predicates_of => { table }
221
233
explicit_implied_predicates_of => { table }
222
234
type_of => { table }
223
- type_alias_is_lazy => { cdata . root . tables . type_alias_is_lazy . get ( cdata , def_id . index ) }
235
+ type_alias_is_lazy => { table_direct }
224
236
variances_of => { table }
225
237
fn_sig => { table }
226
238
codegen_fn_attrs => { table }
@@ -241,7 +253,7 @@ provide! { tcx, def_id, other, cdata,
241
253
lookup_default_body_stability => { table }
242
254
lookup_deprecation_entry => { table }
243
255
params_in_repr => { table }
244
- unused_generic_params => { cdata . root . tables . unused_generic_params . get ( cdata , def_id . index ) }
256
+ unused_generic_params => { table_direct }
245
257
def_kind => { cdata. def_kind( def_id. index) }
246
258
impl_parent => { table }
247
259
defaultness => { table_direct }
@@ -287,9 +299,7 @@ provide! { tcx, def_id, other, cdata,
287
299
. process_decoded( tcx, || panic!( "{def_id:?} does not have trait_impl_trait_tys" ) ) )
288
300
}
289
301
290
- associated_type_for_effects => {
291
- table
292
- }
302
+ associated_type_for_effects => { table }
293
303
associated_types_for_impl_traits_in_associated_fn => { table_defaulted_array }
294
304
295
305
visibility => { cdata. get_visibility( def_id. index) }
@@ -310,7 +320,7 @@ provide! { tcx, def_id, other, cdata,
310
320
item_attrs => { tcx. arena. alloc_from_iter( cdata. get_item_attrs( def_id. index, tcx. sess) ) }
311
321
is_mir_available => { cdata. is_item_mir_available( def_id. index) }
312
322
is_ctfe_mir_available => { cdata. is_ctfe_mir_available( def_id. index) }
313
- cross_crate_inlinable => { cdata . cross_crate_inlinable ( def_id . index ) }
323
+ cross_crate_inlinable => { table_direct }
314
324
315
325
dylib_dependency_formats => { cdata. get_dylib_dependency_formats( tcx) }
316
326
is_private_dep => { cdata. private_dep }
0 commit comments