Skip to main content

rustc_public/unstable/convert/
internal.rs

1//! Module containing the translation from rustc_public constructs to the rustc counterpart.
2//!
3//! This module will only include a few constructs to allow users to invoke internal rustc APIs
4//! due to incomplete stable coverage.
5
6// Prefer importing rustc_public over internal rustc constructs to make this file more readable.
7
8use rustc_middle::ty::{self as rustc_ty, Const as InternalConst, Ty as InternalTy};
9use rustc_public_bridge::Tables;
10
11use crate::abi::Layout;
12use crate::compiler_interface::BridgeTys;
13use crate::mir::alloc::AllocId;
14use crate::mir::mono::{Instance, MonoItem, StaticDef};
15use crate::mir::{BinOp, Mutability, Place, ProjectionElem, RawPtrKind, Safety, UnOp};
16use crate::ty::{
17    Abi, AdtDef, Asyncness, Binder, BoundRegionKind, BoundTyKind, BoundVariableKind, ClosureKind,
18    Constness, ExistentialPredicate, ExistentialProjection, ExistentialTraitRef, FloatTy, FnSig,
19    GenericArgKind, GenericArgs, IntTy, MirConst, Movability, Pattern, Region, RigidTy, Span,
20    TermKind, TraitRef, Ty, TyConst, UintTy, VariantDef, VariantIdx,
21};
22use crate::unstable::{InternalCx, RustcInternal};
23use crate::{CrateItem, CrateNum, DefId, IndexedVal};
24
25impl RustcInternal for CrateItem {
26    type T<'tcx> = rustc_span::def_id::DefId;
27    fn internal<'tcx>(
28        &self,
29        tables: &mut Tables<'_, BridgeTys>,
30        tcx: impl InternalCx<'tcx>,
31    ) -> Self::T<'tcx> {
32        self.0.internal(tables, tcx)
33    }
34}
35
36impl RustcInternal for CrateNum {
37    type T<'tcx> = rustc_span::def_id::CrateNum;
38    fn internal<'tcx>(
39        &self,
40        _tables: &mut Tables<'_, BridgeTys>,
41        _tcx: impl InternalCx<'tcx>,
42    ) -> Self::T<'tcx> {
43        rustc_span::def_id::CrateNum::from_usize(self.0)
44    }
45}
46
47impl RustcInternal for DefId {
48    type T<'tcx> = rustc_span::def_id::DefId;
49    fn internal<'tcx>(
50        &self,
51        tables: &mut Tables<'_, BridgeTys>,
52        tcx: impl InternalCx<'tcx>,
53    ) -> Self::T<'tcx> {
54        tcx.lift(tables.def_ids[*self]).unwrap()
55    }
56}
57
58impl RustcInternal for GenericArgs {
59    type T<'tcx> = rustc_ty::GenericArgsRef<'tcx>;
60    fn internal<'tcx>(
61        &self,
62        tables: &mut Tables<'_, BridgeTys>,
63        tcx: impl InternalCx<'tcx>,
64    ) -> Self::T<'tcx> {
65        InternalCx::mk_args_from_iter(tcx, self.0.iter().map(|arg| arg.internal(tables, tcx)))
66    }
67}
68
69impl RustcInternal for GenericArgKind {
70    type T<'tcx> = rustc_ty::GenericArg<'tcx>;
71    fn internal<'tcx>(
72        &self,
73        tables: &mut Tables<'_, BridgeTys>,
74        tcx: impl InternalCx<'tcx>,
75    ) -> Self::T<'tcx> {
76        let arg: rustc_ty::GenericArg<'tcx> = match self {
77            GenericArgKind::Lifetime(reg) => reg.internal(tables, tcx).into(),
78            GenericArgKind::Type(ty) => ty.internal(tables, tcx).into(),
79            GenericArgKind::Const(cnst) => cnst.internal(tables, tcx).into(),
80        };
81        tcx.lift(arg).unwrap()
82    }
83}
84
85impl RustcInternal for Region {
86    type T<'tcx> = rustc_ty::Region<'tcx>;
87    fn internal<'tcx>(
88        &self,
89        _tables: &mut Tables<'_, BridgeTys>,
90        tcx: impl InternalCx<'tcx>,
91    ) -> Self::T<'tcx> {
92        // Cannot recover region. Use erased for now.
93        tcx.lifetimes_re_erased()
94    }
95}
96
97impl RustcInternal for Ty {
98    type T<'tcx> = InternalTy<'tcx>;
99    fn internal<'tcx>(
100        &self,
101        tables: &mut Tables<'_, BridgeTys>,
102        tcx: impl InternalCx<'tcx>,
103    ) -> Self::T<'tcx> {
104        tcx.lift(tables.types[*self]).unwrap()
105    }
106}
107
108impl RustcInternal for TyConst {
109    type T<'tcx> = InternalConst<'tcx>;
110    fn internal<'tcx>(
111        &self,
112        tables: &mut Tables<'_, BridgeTys>,
113        tcx: impl InternalCx<'tcx>,
114    ) -> Self::T<'tcx> {
115        tcx.lift(tables.ty_consts[self.id]).unwrap()
116    }
117}
118
119impl RustcInternal for Pattern {
120    type T<'tcx> = rustc_ty::Pattern<'tcx>;
121    fn internal<'tcx>(
122        &self,
123        tables: &mut Tables<'_, BridgeTys>,
124        tcx: impl InternalCx<'tcx>,
125    ) -> Self::T<'tcx> {
126        tcx.mk_pat(match self {
127            Pattern::Range { start, end, include_end: _ } => rustc_ty::PatternKind::Range {
128                start: start.internal(tables, tcx),
129                end: end.internal(tables, tcx),
130            },
131            Pattern::NotNull => rustc_ty::PatternKind::NotNull,
132            Pattern::Or(patterns) => rustc_ty::PatternKind::Or(
133                tcx.mk_patterns_from_iter(patterns.iter().map(|p| p.internal(tables, tcx))),
134            ),
135        })
136    }
137}
138
139impl RustcInternal for RigidTy {
140    type T<'tcx> = rustc_ty::TyKind<'tcx>;
141
142    fn internal<'tcx>(
143        &self,
144        tables: &mut Tables<'_, BridgeTys>,
145        tcx: impl InternalCx<'tcx>,
146    ) -> Self::T<'tcx> {
147        match self {
148            RigidTy::Bool => rustc_ty::TyKind::Bool,
149            RigidTy::Char => rustc_ty::TyKind::Char,
150            RigidTy::Int(int_ty) => rustc_ty::TyKind::Int(int_ty.internal(tables, tcx)),
151            RigidTy::Uint(uint_ty) => rustc_ty::TyKind::Uint(uint_ty.internal(tables, tcx)),
152            RigidTy::Float(float_ty) => rustc_ty::TyKind::Float(float_ty.internal(tables, tcx)),
153            RigidTy::Never => rustc_ty::TyKind::Never,
154            RigidTy::Array(ty, cnst) => {
155                rustc_ty::TyKind::Array(ty.internal(tables, tcx), cnst.internal(tables, tcx))
156            }
157            RigidTy::Pat(ty, pat) => {
158                rustc_ty::TyKind::Pat(ty.internal(tables, tcx), pat.internal(tables, tcx))
159            }
160            RigidTy::Adt(def, args) => {
161                rustc_ty::TyKind::Adt(def.internal(tables, tcx), args.internal(tables, tcx))
162            }
163            RigidTy::Str => rustc_ty::TyKind::Str,
164            RigidTy::Slice(ty) => rustc_ty::TyKind::Slice(ty.internal(tables, tcx)),
165            RigidTy::RawPtr(ty, mutability) => {
166                rustc_ty::TyKind::RawPtr(ty.internal(tables, tcx), mutability.internal(tables, tcx))
167            }
168            RigidTy::Ref(region, ty, mutability) => rustc_ty::TyKind::Ref(
169                region.internal(tables, tcx),
170                ty.internal(tables, tcx),
171                mutability.internal(tables, tcx),
172            ),
173            RigidTy::Foreign(def) => rustc_ty::TyKind::Foreign(def.0.internal(tables, tcx)),
174            RigidTy::FnDef(def, args) => {
175                rustc_ty::TyKind::FnDef(def.0.internal(tables, tcx), args.internal(tables, tcx))
176            }
177            RigidTy::FnPtr(sig) => {
178                let (sig_tys, hdr) = sig.internal(tables, tcx).split();
179                rustc_ty::TyKind::FnPtr(sig_tys, hdr)
180            }
181            RigidTy::Closure(def, args) => {
182                rustc_ty::TyKind::Closure(def.0.internal(tables, tcx), args.internal(tables, tcx))
183            }
184            RigidTy::Coroutine(def, args) => {
185                rustc_ty::TyKind::Coroutine(def.0.internal(tables, tcx), args.internal(tables, tcx))
186            }
187            RigidTy::CoroutineClosure(def, args) => rustc_ty::TyKind::CoroutineClosure(
188                def.0.internal(tables, tcx),
189                args.internal(tables, tcx),
190            ),
191            RigidTy::CoroutineWitness(def, args) => rustc_ty::TyKind::CoroutineWitness(
192                def.0.internal(tables, tcx),
193                args.internal(tables, tcx),
194            ),
195            RigidTy::Dynamic(predicate, region) => rustc_ty::TyKind::Dynamic(
196                tcx.mk_poly_existential_predicates(&predicate.internal(tables, tcx)),
197                region.internal(tables, tcx),
198            ),
199            RigidTy::Tuple(tys) => {
200                rustc_ty::TyKind::Tuple(tcx.mk_type_list(&tys.internal(tables, tcx)))
201            }
202        }
203    }
204}
205
206impl RustcInternal for IntTy {
207    type T<'tcx> = rustc_ty::IntTy;
208
209    fn internal<'tcx>(
210        &self,
211        _tables: &mut Tables<'_, BridgeTys>,
212        _tcx: impl InternalCx<'tcx>,
213    ) -> Self::T<'tcx> {
214        match self {
215            IntTy::Isize => rustc_ty::IntTy::Isize,
216            IntTy::I8 => rustc_ty::IntTy::I8,
217            IntTy::I16 => rustc_ty::IntTy::I16,
218            IntTy::I32 => rustc_ty::IntTy::I32,
219            IntTy::I64 => rustc_ty::IntTy::I64,
220            IntTy::I128 => rustc_ty::IntTy::I128,
221        }
222    }
223}
224
225impl RustcInternal for UintTy {
226    type T<'tcx> = rustc_ty::UintTy;
227
228    fn internal<'tcx>(
229        &self,
230        _tables: &mut Tables<'_, BridgeTys>,
231        _tcx: impl InternalCx<'tcx>,
232    ) -> Self::T<'tcx> {
233        match self {
234            UintTy::Usize => rustc_ty::UintTy::Usize,
235            UintTy::U8 => rustc_ty::UintTy::U8,
236            UintTy::U16 => rustc_ty::UintTy::U16,
237            UintTy::U32 => rustc_ty::UintTy::U32,
238            UintTy::U64 => rustc_ty::UintTy::U64,
239            UintTy::U128 => rustc_ty::UintTy::U128,
240        }
241    }
242}
243
244impl RustcInternal for FloatTy {
245    type T<'tcx> = rustc_ty::FloatTy;
246
247    fn internal<'tcx>(
248        &self,
249        _tables: &mut Tables<'_, BridgeTys>,
250        _tcx: impl InternalCx<'tcx>,
251    ) -> Self::T<'tcx> {
252        match self {
253            FloatTy::F16 => rustc_ty::FloatTy::F16,
254            FloatTy::F32 => rustc_ty::FloatTy::F32,
255            FloatTy::F64 => rustc_ty::FloatTy::F64,
256            FloatTy::F128 => rustc_ty::FloatTy::F128,
257        }
258    }
259}
260
261impl RustcInternal for Mutability {
262    type T<'tcx> = rustc_ty::Mutability;
263
264    fn internal<'tcx>(
265        &self,
266        _tables: &mut Tables<'_, BridgeTys>,
267        _tcx: impl InternalCx<'tcx>,
268    ) -> Self::T<'tcx> {
269        match self {
270            Mutability::Not => rustc_ty::Mutability::Not,
271            Mutability::Mut => rustc_ty::Mutability::Mut,
272        }
273    }
274}
275
276impl RustcInternal for Movability {
277    type T<'tcx> = rustc_ty::Movability;
278
279    fn internal<'tcx>(
280        &self,
281        _tables: &mut Tables<'_, BridgeTys>,
282        _tcx: impl InternalCx<'tcx>,
283    ) -> Self::T<'tcx> {
284        match self {
285            Movability::Static => rustc_ty::Movability::Static,
286            Movability::Movable => rustc_ty::Movability::Movable,
287        }
288    }
289}
290
291impl RustcInternal for RawPtrKind {
292    type T<'tcx> = rustc_middle::mir::RawPtrKind;
293
294    fn internal<'tcx>(
295        &self,
296        _tables: &mut Tables<'_, BridgeTys>,
297        _tcx: impl InternalCx<'tcx>,
298    ) -> Self::T<'tcx> {
299        match self {
300            RawPtrKind::Mut => rustc_middle::mir::RawPtrKind::Mut,
301            RawPtrKind::Const => rustc_middle::mir::RawPtrKind::Const,
302            RawPtrKind::FakeForPtrMetadata => rustc_middle::mir::RawPtrKind::FakeForPtrMetadata,
303        }
304    }
305}
306
307impl RustcInternal for FnSig {
308    type T<'tcx> = rustc_ty::FnSig<'tcx>;
309
310    fn internal<'tcx>(
311        &self,
312        tables: &mut Tables<'_, BridgeTys>,
313        tcx: impl InternalCx<'tcx>,
314    ) -> Self::T<'tcx> {
315        let fn_sig_kind = rustc_ty::FnSigKind::default()
316            .set_abi(self.abi.internal(tables, tcx))
317            .set_safety(self.safety.internal(tables, tcx))
318            .set_c_variadic(self.c_variadic);
319        tcx.lift(rustc_ty::FnSig {
320            inputs_and_output: tcx.mk_type_list(&self.inputs_and_output.internal(tables, tcx)),
321            fn_sig_kind,
322        })
323        .unwrap()
324    }
325}
326
327impl RustcInternal for VariantIdx {
328    type T<'tcx> = rustc_abi::VariantIdx;
329
330    fn internal<'tcx>(
331        &self,
332        _tables: &mut Tables<'_, BridgeTys>,
333        _tcx: impl InternalCx<'tcx>,
334    ) -> Self::T<'tcx> {
335        rustc_abi::VariantIdx::from(self.to_index())
336    }
337}
338
339impl RustcInternal for VariantDef {
340    type T<'tcx> = &'tcx rustc_ty::VariantDef;
341
342    fn internal<'tcx>(
343        &self,
344        tables: &mut Tables<'_, BridgeTys>,
345        tcx: impl InternalCx<'tcx>,
346    ) -> Self::T<'tcx> {
347        self.adt_def.internal(tables, tcx).variant(self.idx.internal(tables, tcx))
348    }
349}
350
351impl RustcInternal for MirConst {
352    type T<'tcx> = rustc_middle::mir::Const<'tcx>;
353    fn internal<'tcx>(
354        &self,
355        tables: &mut Tables<'_, BridgeTys>,
356        tcx: impl InternalCx<'tcx>,
357    ) -> Self::T<'tcx> {
358        let constant = tables.mir_consts[self.id];
359        match constant {
360            rustc_middle::mir::Const::Ty(ty, ct) => {
361                rustc_middle::mir::Const::Ty(tcx.lift(ty).unwrap(), tcx.lift(ct).unwrap())
362            }
363            rustc_middle::mir::Const::Unevaluated(uneval, ty) => {
364                rustc_middle::mir::Const::Unevaluated(
365                    tcx.lift(uneval).unwrap(),
366                    tcx.lift(ty).unwrap(),
367                )
368            }
369            rustc_middle::mir::Const::Val(const_val, ty) => {
370                rustc_middle::mir::Const::Val(tcx.lift(const_val).unwrap(), tcx.lift(ty).unwrap())
371            }
372        }
373    }
374}
375
376impl RustcInternal for MonoItem {
377    type T<'tcx> = rustc_middle::mono::MonoItem<'tcx>;
378
379    fn internal<'tcx>(
380        &self,
381        tables: &mut Tables<'_, BridgeTys>,
382        tcx: impl InternalCx<'tcx>,
383    ) -> Self::T<'tcx> {
384        use rustc_middle::mono as rustc_mono;
385        match self {
386            MonoItem::Fn(instance) => rustc_mono::MonoItem::Fn(instance.internal(tables, tcx)),
387            MonoItem::Static(def) => rustc_mono::MonoItem::Static(def.internal(tables, tcx)),
388            MonoItem::GlobalAsm(_) => {
389                ::core::panicking::panic("not implemented")unimplemented!()
390            }
391        }
392    }
393}
394
395impl RustcInternal for Instance {
396    type T<'tcx> = rustc_ty::Instance<'tcx>;
397
398    fn internal<'tcx>(
399        &self,
400        tables: &mut Tables<'_, BridgeTys>,
401        tcx: impl InternalCx<'tcx>,
402    ) -> Self::T<'tcx> {
403        tcx.lift(tables.instances[self.def]).unwrap()
404    }
405}
406
407impl RustcInternal for StaticDef {
408    type T<'tcx> = rustc_span::def_id::DefId;
409
410    fn internal<'tcx>(
411        &self,
412        tables: &mut Tables<'_, BridgeTys>,
413        tcx: impl InternalCx<'tcx>,
414    ) -> Self::T<'tcx> {
415        self.0.internal(tables, tcx)
416    }
417}
418
419#[allow(rustc::usage_of_qualified_ty)]
420impl<T> RustcInternal for Binder<T>
421where
422    T: RustcInternal,
423    for<'tcx> T::T<'tcx>: rustc_ty::TypeVisitable<rustc_ty::TyCtxt<'tcx>>,
424{
425    type T<'tcx> = rustc_ty::Binder<'tcx, T::T<'tcx>>;
426
427    fn internal<'tcx>(
428        &self,
429        tables: &mut Tables<'_, BridgeTys>,
430        tcx: impl InternalCx<'tcx>,
431    ) -> Self::T<'tcx> {
432        rustc_ty::Binder::bind_with_vars(
433            self.value.internal(tables, tcx),
434            tcx.mk_bound_variable_kinds_from_iter(
435                self.bound_vars.iter().map(|bound| bound.internal(tables, tcx)),
436            ),
437        )
438    }
439}
440
441impl RustcInternal for BoundVariableKind {
442    type T<'tcx> = rustc_ty::BoundVariableKind<'tcx>;
443
444    fn internal<'tcx>(
445        &self,
446        tables: &mut Tables<'_, BridgeTys>,
447        tcx: impl InternalCx<'tcx>,
448    ) -> Self::T<'tcx> {
449        match self {
450            BoundVariableKind::Ty(kind) => rustc_ty::BoundVariableKind::Ty(match kind {
451                BoundTyKind::Anon => rustc_ty::BoundTyKind::Anon,
452                BoundTyKind::Param(def, _symbol) => {
453                    rustc_ty::BoundTyKind::Param(def.0.internal(tables, tcx))
454                }
455            }),
456            BoundVariableKind::Region(kind) => rustc_ty::BoundVariableKind::Region(match kind {
457                BoundRegionKind::BrAnon => rustc_ty::BoundRegionKind::Anon,
458                BoundRegionKind::BrNamed(def, _symbol) => {
459                    rustc_ty::BoundRegionKind::Named(def.0.internal(tables, tcx))
460                }
461                BoundRegionKind::BrEnv => rustc_ty::BoundRegionKind::ClosureEnv,
462            }),
463            BoundVariableKind::Const => rustc_ty::BoundVariableKind::Const,
464        }
465    }
466}
467
468impl RustcInternal for ExistentialPredicate {
469    type T<'tcx> = rustc_ty::ExistentialPredicate<'tcx>;
470
471    fn internal<'tcx>(
472        &self,
473        tables: &mut Tables<'_, BridgeTys>,
474        tcx: impl InternalCx<'tcx>,
475    ) -> Self::T<'tcx> {
476        match self {
477            ExistentialPredicate::Trait(trait_ref) => {
478                rustc_ty::ExistentialPredicate::Trait(trait_ref.internal(tables, tcx))
479            }
480            ExistentialPredicate::Projection(proj) => {
481                rustc_ty::ExistentialPredicate::Projection(proj.internal(tables, tcx))
482            }
483            ExistentialPredicate::AutoTrait(trait_def) => {
484                rustc_ty::ExistentialPredicate::AutoTrait(trait_def.0.internal(tables, tcx))
485            }
486        }
487    }
488}
489
490impl RustcInternal for ExistentialProjection {
491    type T<'tcx> = rustc_ty::ExistentialProjection<'tcx>;
492
493    fn internal<'tcx>(
494        &self,
495        tables: &mut Tables<'_, BridgeTys>,
496        tcx: impl InternalCx<'tcx>,
497    ) -> Self::T<'tcx> {
498        use crate::unstable::internal_cx::ExistentialProjectionHelpers;
499        tcx.new_from_args(
500            self.def_id.0.internal(tables, tcx),
501            self.generic_args.internal(tables, tcx),
502            self.term.internal(tables, tcx),
503        )
504    }
505}
506
507impl RustcInternal for TermKind {
508    type T<'tcx> = rustc_ty::Term<'tcx>;
509
510    fn internal<'tcx>(
511        &self,
512        tables: &mut Tables<'_, BridgeTys>,
513        tcx: impl InternalCx<'tcx>,
514    ) -> Self::T<'tcx> {
515        match self {
516            TermKind::Type(ty) => ty.internal(tables, tcx).into(),
517            TermKind::Const(cnst) => cnst.internal(tables, tcx).into(),
518        }
519    }
520}
521
522impl RustcInternal for ExistentialTraitRef {
523    type T<'tcx> = rustc_ty::ExistentialTraitRef<'tcx>;
524
525    fn internal<'tcx>(
526        &self,
527        tables: &mut Tables<'_, BridgeTys>,
528        tcx: impl InternalCx<'tcx>,
529    ) -> Self::T<'tcx> {
530        use crate::unstable::internal_cx::ExistentialTraitRefHelpers;
531        tcx.new_from_args(
532            self.def_id.0.internal(tables, tcx),
533            self.generic_args.internal(tables, tcx),
534        )
535    }
536}
537
538impl RustcInternal for TraitRef {
539    type T<'tcx> = rustc_ty::TraitRef<'tcx>;
540
541    fn internal<'tcx>(
542        &self,
543        tables: &mut Tables<'_, BridgeTys>,
544        tcx: impl InternalCx<'tcx>,
545    ) -> Self::T<'tcx> {
546        use crate::unstable::internal_cx::TraitRefHelpers;
547        tcx.new_from_args(self.def_id.0.internal(tables, tcx), self.args().internal(tables, tcx))
548    }
549}
550
551impl RustcInternal for AllocId {
552    type T<'tcx> = rustc_middle::mir::interpret::AllocId;
553    fn internal<'tcx>(
554        &self,
555        tables: &mut Tables<'_, BridgeTys>,
556        tcx: impl InternalCx<'tcx>,
557    ) -> Self::T<'tcx> {
558        tcx.lift(tables.alloc_ids[*self]).unwrap()
559    }
560}
561
562impl RustcInternal for ClosureKind {
563    type T<'tcx> = rustc_ty::ClosureKind;
564
565    fn internal<'tcx>(
566        &self,
567        _tables: &mut Tables<'_, BridgeTys>,
568        _tcx: impl InternalCx<'tcx>,
569    ) -> Self::T<'tcx> {
570        match self {
571            ClosureKind::Fn => rustc_ty::ClosureKind::Fn,
572            ClosureKind::FnMut => rustc_ty::ClosureKind::FnMut,
573            ClosureKind::FnOnce => rustc_ty::ClosureKind::FnOnce,
574        }
575    }
576}
577
578impl RustcInternal for AdtDef {
579    type T<'tcx> = rustc_ty::AdtDef<'tcx>;
580    fn internal<'tcx>(
581        &self,
582        tables: &mut Tables<'_, BridgeTys>,
583        tcx: impl InternalCx<'tcx>,
584    ) -> Self::T<'tcx> {
585        InternalCx::adt_def(tcx, self.0.internal(tables, tcx))
586    }
587}
588
589impl RustcInternal for Abi {
590    type T<'tcx> = rustc_abi::ExternAbi;
591
592    fn internal<'tcx>(
593        &self,
594        _tables: &mut Tables<'_, BridgeTys>,
595        _tcx: impl InternalCx<'tcx>,
596    ) -> Self::T<'tcx> {
597        match *self {
598            Abi::Rust => rustc_abi::ExternAbi::Rust,
599            Abi::C { unwind } => rustc_abi::ExternAbi::C { unwind },
600            Abi::Cdecl { unwind } => rustc_abi::ExternAbi::Cdecl { unwind },
601            Abi::Stdcall { unwind } => rustc_abi::ExternAbi::Stdcall { unwind },
602            Abi::Fastcall { unwind } => rustc_abi::ExternAbi::Fastcall { unwind },
603            Abi::Vectorcall { unwind } => rustc_abi::ExternAbi::Vectorcall { unwind },
604            Abi::Thiscall { unwind } => rustc_abi::ExternAbi::Thiscall { unwind },
605            Abi::Aapcs { unwind } => rustc_abi::ExternAbi::Aapcs { unwind },
606            Abi::CCmseNonSecureCall => rustc_abi::ExternAbi::CmseNonSecureCall,
607            Abi::CCmseNonSecureEntry => rustc_abi::ExternAbi::CmseNonSecureEntry,
608            Abi::Win64 { unwind } => rustc_abi::ExternAbi::Win64 { unwind },
609            Abi::SysV64 { unwind } => rustc_abi::ExternAbi::SysV64 { unwind },
610            Abi::PtxKernel => rustc_abi::ExternAbi::PtxKernel,
611            Abi::Msp430Interrupt => rustc_abi::ExternAbi::Msp430Interrupt,
612            Abi::X86Interrupt => rustc_abi::ExternAbi::X86Interrupt,
613            Abi::GpuKernel => rustc_abi::ExternAbi::GpuKernel,
614            Abi::EfiApi => rustc_abi::ExternAbi::EfiApi,
615            Abi::AvrInterrupt => rustc_abi::ExternAbi::AvrInterrupt,
616            Abi::AvrNonBlockingInterrupt => rustc_abi::ExternAbi::AvrNonBlockingInterrupt,
617            Abi::System { unwind } => rustc_abi::ExternAbi::System { unwind },
618            Abi::RustCall => rustc_abi::ExternAbi::RustCall,
619            Abi::Unadjusted => rustc_abi::ExternAbi::Unadjusted,
620            Abi::RustCold => rustc_abi::ExternAbi::RustCold,
621            Abi::RustInvalid => rustc_abi::ExternAbi::RustInvalid,
622            Abi::RiscvInterruptM => rustc_abi::ExternAbi::RiscvInterruptM,
623            Abi::RiscvInterruptS => rustc_abi::ExternAbi::RiscvInterruptS,
624            Abi::RustPreserveNone => rustc_abi::ExternAbi::RustPreserveNone,
625            Abi::Custom => rustc_abi::ExternAbi::Custom,
626        }
627    }
628}
629
630impl RustcInternal for Safety {
631    type T<'tcx> = rustc_hir::Safety;
632
633    fn internal<'tcx>(
634        &self,
635        _tables: &mut Tables<'_, BridgeTys>,
636        _tcx: impl InternalCx<'tcx>,
637    ) -> Self::T<'tcx> {
638        match self {
639            Safety::Unsafe => rustc_hir::Safety::Unsafe,
640            Safety::Safe => rustc_hir::Safety::Safe,
641        }
642    }
643}
644
645impl RustcInternal for Constness {
646    type T<'tcx> = rustc_hir::Constness;
647
648    fn internal<'tcx>(
649        &self,
650        _tables: &mut Tables<'_, BridgeTys>,
651        _tcx: impl InternalCx<'tcx>,
652    ) -> Self::T<'tcx> {
653        match self {
654            Constness::Const => rustc_hir::Constness::Const,
655            Constness::NotConst => rustc_hir::Constness::NotConst,
656        }
657    }
658}
659
660impl RustcInternal for Asyncness {
661    type T<'tcx> = rustc_ty::Asyncness;
662
663    fn internal<'tcx>(
664        &self,
665        _tables: &mut Tables<'_, BridgeTys>,
666        _tcx: impl InternalCx<'tcx>,
667    ) -> Self::T<'tcx> {
668        match self {
669            Asyncness::Async => rustc_ty::Asyncness::Yes,
670            Asyncness::NotAsync => rustc_ty::Asyncness::No,
671        }
672    }
673}
674impl RustcInternal for Span {
675    type T<'tcx> = rustc_span::Span;
676
677    fn internal<'tcx>(
678        &self,
679        tables: &mut Tables<'_, BridgeTys>,
680        _tcx: impl InternalCx<'tcx>,
681    ) -> Self::T<'tcx> {
682        tables.spans[*self]
683    }
684}
685
686impl RustcInternal for Layout {
687    type T<'tcx> = rustc_abi::Layout<'tcx>;
688
689    fn internal<'tcx>(
690        &self,
691        tables: &mut Tables<'_, BridgeTys>,
692        tcx: impl InternalCx<'tcx>,
693    ) -> Self::T<'tcx> {
694        tcx.lift(tables.layouts[*self]).unwrap()
695    }
696}
697
698impl RustcInternal for Place {
699    type T<'tcx> = rustc_middle::mir::Place<'tcx>;
700
701    fn internal<'tcx>(
702        &self,
703        tables: &mut Tables<'_, BridgeTys>,
704        tcx: impl InternalCx<'tcx>,
705    ) -> Self::T<'tcx> {
706        rustc_middle::mir::Place {
707            local: rustc_middle::mir::Local::from_usize(self.local),
708            projection: tcx.mk_place_elems(&self.projection.internal(tables, tcx)),
709        }
710    }
711}
712
713impl RustcInternal for ProjectionElem {
714    type T<'tcx> = rustc_middle::mir::PlaceElem<'tcx>;
715
716    fn internal<'tcx>(
717        &self,
718        tables: &mut Tables<'_, BridgeTys>,
719        tcx: impl InternalCx<'tcx>,
720    ) -> Self::T<'tcx> {
721        match self {
722            ProjectionElem::Deref => rustc_middle::mir::PlaceElem::Deref,
723            ProjectionElem::Field(idx, ty) => {
724                rustc_middle::mir::PlaceElem::Field((*idx).into(), ty.internal(tables, tcx))
725            }
726            ProjectionElem::Index(idx) => rustc_middle::mir::PlaceElem::Index((*idx).into()),
727            ProjectionElem::ConstantIndex { offset, min_length, from_end } => {
728                rustc_middle::mir::PlaceElem::ConstantIndex {
729                    offset: *offset,
730                    min_length: *min_length,
731                    from_end: *from_end,
732                }
733            }
734            ProjectionElem::Subslice { from, to, from_end } => {
735                rustc_middle::mir::PlaceElem::Subslice { from: *from, to: *to, from_end: *from_end }
736            }
737            ProjectionElem::Downcast(idx) => {
738                rustc_middle::mir::PlaceElem::Downcast(None, idx.internal(tables, tcx))
739            }
740            ProjectionElem::OpaqueCast(ty) => {
741                rustc_middle::mir::PlaceElem::OpaqueCast(ty.internal(tables, tcx))
742            }
743        }
744    }
745}
746
747impl RustcInternal for BinOp {
748    type T<'tcx> = rustc_middle::mir::BinOp;
749
750    fn internal<'tcx>(
751        &self,
752        _tables: &mut Tables<'_, BridgeTys>,
753        _tcx: impl InternalCx<'tcx>,
754    ) -> Self::T<'tcx> {
755        match self {
756            BinOp::Add => rustc_middle::mir::BinOp::Add,
757            BinOp::AddUnchecked => rustc_middle::mir::BinOp::AddUnchecked,
758            BinOp::Sub => rustc_middle::mir::BinOp::Sub,
759            BinOp::SubUnchecked => rustc_middle::mir::BinOp::SubUnchecked,
760            BinOp::Mul => rustc_middle::mir::BinOp::Mul,
761            BinOp::MulUnchecked => rustc_middle::mir::BinOp::MulUnchecked,
762            BinOp::Div => rustc_middle::mir::BinOp::Div,
763            BinOp::Rem => rustc_middle::mir::BinOp::Rem,
764            BinOp::BitXor => rustc_middle::mir::BinOp::BitXor,
765            BinOp::BitAnd => rustc_middle::mir::BinOp::BitAnd,
766            BinOp::BitOr => rustc_middle::mir::BinOp::BitOr,
767            BinOp::Shl => rustc_middle::mir::BinOp::Shl,
768            BinOp::ShlUnchecked => rustc_middle::mir::BinOp::ShlUnchecked,
769            BinOp::Shr => rustc_middle::mir::BinOp::Shr,
770            BinOp::ShrUnchecked => rustc_middle::mir::BinOp::ShrUnchecked,
771            BinOp::Eq => rustc_middle::mir::BinOp::Eq,
772            BinOp::Lt => rustc_middle::mir::BinOp::Lt,
773            BinOp::Le => rustc_middle::mir::BinOp::Le,
774            BinOp::Ne => rustc_middle::mir::BinOp::Ne,
775            BinOp::Ge => rustc_middle::mir::BinOp::Ge,
776            BinOp::Gt => rustc_middle::mir::BinOp::Gt,
777            BinOp::Cmp => rustc_middle::mir::BinOp::Cmp,
778            BinOp::Offset => rustc_middle::mir::BinOp::Offset,
779        }
780    }
781}
782
783impl RustcInternal for UnOp {
784    type T<'tcx> = rustc_middle::mir::UnOp;
785
786    fn internal<'tcx>(
787        &self,
788        _tables: &mut Tables<'_, BridgeTys>,
789        _tcx: impl InternalCx<'tcx>,
790    ) -> Self::T<'tcx> {
791        match self {
792            UnOp::Not => rustc_middle::mir::UnOp::Not,
793            UnOp::Neg => rustc_middle::mir::UnOp::Neg,
794            UnOp::PtrMetadata => rustc_middle::mir::UnOp::PtrMetadata,
795        }
796    }
797}
798
799impl<T> RustcInternal for &T
800where
801    T: RustcInternal,
802{
803    type T<'tcx> = T::T<'tcx>;
804
805    fn internal<'tcx>(
806        &self,
807        tables: &mut Tables<'_, BridgeTys>,
808        tcx: impl InternalCx<'tcx>,
809    ) -> Self::T<'tcx> {
810        (*self).internal(tables, tcx)
811    }
812}
813
814impl<T> RustcInternal for Option<T>
815where
816    T: RustcInternal,
817{
818    type T<'tcx> = Option<T::T<'tcx>>;
819
820    fn internal<'tcx>(
821        &self,
822        tables: &mut Tables<'_, BridgeTys>,
823        tcx: impl InternalCx<'tcx>,
824    ) -> Self::T<'tcx> {
825        self.as_ref().map(|inner| inner.internal(tables, tcx))
826    }
827}
828
829impl<T> RustcInternal for Vec<T>
830where
831    T: RustcInternal,
832{
833    type T<'tcx> = Vec<T::T<'tcx>>;
834
835    fn internal<'tcx>(
836        &self,
837        tables: &mut Tables<'_, BridgeTys>,
838        tcx: impl InternalCx<'tcx>,
839    ) -> Self::T<'tcx> {
840        self.iter().map(|e| e.internal(tables, tcx)).collect()
841    }
842}