1use std::fmt;
2use std::hash::Hash;
3use std::marker::PhantomData;
4use std::ops::{ControlFlow, Deref};
5
6use derive_where::derive_where;
7#[cfg(feature = "nightly")]
8use rustc_macros::{Decodable_NoContext, Encodable_NoContext, StableHash, StableHash_NoContext};
9use rustc_type_ir_macros::{
10 GenericTypeVisitable, Lift_Generic, TypeFoldable_Generic, TypeVisitable_Generic,
11};
12use tracing::instrument;
13
14use crate::data_structures::SsoHashSet;
15use crate::fold::{FallibleTypeFolder, TypeFoldable, TypeFolder, TypeSuperFoldable};
16use crate::inherent::*;
17use crate::lift::Lift;
18use crate::visit::{Flags, TypeSuperVisitable, TypeVisitable, TypeVisitableExt, TypeVisitor};
19use crate::{self as ty, DebruijnIndex, Interner, UniverseIndex, Unnormalized};
20
21#[automatically_derived]
impl<I: Interner, T> ::core::fmt::Debug for Binder<I, T> where I: Interner,
T: ::core::fmt::Debug {
fn fmt(&self, __f: &mut ::core::fmt::Formatter<'_>)
-> ::core::fmt::Result {
match self {
Binder {
value: ref __field_value, bound_vars: ref __field_bound_vars }
=> {
let mut __builder =
::core::fmt::Formatter::debug_struct(__f, "Binder");
::core::fmt::DebugStruct::field(&mut __builder, "value",
__field_value);
::core::fmt::DebugStruct::field(&mut __builder, "bound_vars",
__field_bound_vars);
::core::fmt::DebugStruct::finish(&mut __builder)
}
}
}
}#[derive_where(Clone, Copy, Hash, PartialEq, Debug; I: Interner, T)]
30#[derive(GenericTypeVisitable)]
31#[cfg_attr(feature = "nightly", derive(const _: () =
{
impl<I: Interner, T>
::rustc_data_structures::stable_hasher::StableHash for
Binder<I, T> where
T: ::rustc_data_structures::stable_hasher::StableHash,
I::BoundVarKinds: ::rustc_data_structures::stable_hasher::StableHash
{
#[inline]
fn stable_hash<__Hcx: ::rustc_data_structures::stable_hasher::StableHashCtxt>(&self,
__hcx: &mut __Hcx,
__hasher:
&mut ::rustc_data_structures::stable_hasher::StableHasher) {
match *self {
Binder { value: ref __binding_0, bound_vars: ref __binding_1
} => {
{ __binding_0.stable_hash(__hcx, __hasher); }
{ __binding_1.stable_hash(__hcx, __hasher); }
}
}
}
}
};StableHash_NoContext))]
32pub struct Binder<I: Interner, T> {
33 value: T,
34 bound_vars: I::BoundVarKinds,
35}
36
37impl<I: Interner, T: Eq> Eq for Binder<I, T> {}
38
39impl<I: Interner, U: Interner, T> Lift<U> for Binder<I, T>
42where
43 T: Lift<U>,
44 I::BoundVarKinds: Lift<U, Lifted = U::BoundVarKinds>,
45{
46 type Lifted = Binder<U, T::Lifted>;
47
48 fn lift_to_interner(self, cx: U) -> Self::Lifted {
49 Binder {
50 value: self.value.lift_to_interner(cx),
51 bound_vars: self.bound_vars.lift_to_interner(cx),
52 }
53 }
54}
55
56#[cfg(feature = "nightly")]
57macro_rules! impl_binder_encode_decode {
58 ($($t:ty),+ $(,)?) => {
59 $(
60 impl<I: Interner, E: rustc_serialize::Encoder> rustc_serialize::Encodable<E> for ty::Binder<I, $t>
61 where
62 $t: rustc_serialize::Encodable<E>,
63 I::BoundVarKinds: rustc_serialize::Encodable<E>,
64 {
65 fn encode(&self, e: &mut E) {
66 self.bound_vars().encode(e);
67 self.as_ref().skip_binder().encode(e);
68 }
69 }
70 impl<I: Interner, D: rustc_serialize::Decoder> rustc_serialize::Decodable<D> for ty::Binder<I, $t>
71 where
72 $t: TypeVisitable<I> + rustc_serialize::Decodable<D>,
73 I::BoundVarKinds: rustc_serialize::Decodable<D>,
74 {
75 fn decode(decoder: &mut D) -> Self {
76 let bound_vars = rustc_serialize::Decodable::decode(decoder);
77 ty::Binder::bind_with_vars(rustc_serialize::Decodable::decode(decoder), bound_vars)
78 }
79 }
80 )*
81 }
82}
83
84#[cfg(feature = "nightly")]
85impl<I: Interner, E: rustc_serialize::Encoder> rustc_serialize::Encodable<E>
for ty::Binder<I, ty::HostEffectPredicate<I>> where
ty::HostEffectPredicate<I>: rustc_serialize::Encodable<E>,
I::BoundVarKinds: rustc_serialize::Encodable<E> {
fn encode(&self, e: &mut E) {
self.bound_vars().encode(e);
self.as_ref().skip_binder().encode(e);
}
}
impl<I: Interner, D: rustc_serialize::Decoder> rustc_serialize::Decodable<D>
for ty::Binder<I, ty::HostEffectPredicate<I>> where
ty::HostEffectPredicate<I>: TypeVisitable<I> +
rustc_serialize::Decodable<D>,
I::BoundVarKinds: rustc_serialize::Decodable<D> {
fn decode(decoder: &mut D) -> Self {
let bound_vars = rustc_serialize::Decodable::decode(decoder);
ty::Binder::bind_with_vars(rustc_serialize::Decodable::decode(decoder),
bound_vars)
}
}impl_binder_encode_decode! {
86 ty::FnSig<I>,
87 ty::FnSigTys<I>,
88 ty::TraitPredicate<I>,
89 ty::ExistentialPredicate<I>,
90 ty::TraitRef<I>,
91 ty::ExistentialTraitRef<I>,
92 ty::HostEffectPredicate<I>,
93}
94
95impl<I: Interner, T> Binder<I, T>
96where
97 T: TypeVisitable<I>,
98{
99 #[track_caller]
104 pub fn dummy(value: T) -> Binder<I, T> {
105 if !!value.has_escaping_bound_vars() {
{
::core::panicking::panic_fmt(format_args!("`{0:?}` has escaping bound vars, so it cannot be wrapped in a dummy binder.",
value));
}
};assert!(
106 !value.has_escaping_bound_vars(),
107 "`{value:?}` has escaping bound vars, so it cannot be wrapped in a dummy binder."
108 );
109 Binder { value, bound_vars: Default::default() }
110 }
111
112 pub fn bind_with_vars(value: T, bound_vars: I::BoundVarKinds) -> Binder<I, T> {
113 if truecfg!(debug_assertions) {
114 let mut validator = ValidateBoundVars::new(bound_vars);
115 let _ = value.visit_with(&mut validator);
116 }
117 Binder { value, bound_vars }
118 }
119}
120
121impl<I: Interner, T: TypeFoldable<I>> TypeFoldable<I> for Binder<I, T> {
122 fn try_fold_with<F: FallibleTypeFolder<I>>(self, folder: &mut F) -> Result<Self, F::Error> {
123 folder.try_fold_binder(self)
124 }
125
126 fn fold_with<F: TypeFolder<I>>(self, folder: &mut F) -> Self {
127 folder.fold_binder(self)
128 }
129}
130
131impl<I: Interner, T: TypeVisitable<I>> TypeVisitable<I> for Binder<I, T> {
132 fn visit_with<V: TypeVisitor<I>>(&self, visitor: &mut V) -> V::Result {
133 visitor.visit_binder(self)
134 }
135}
136
137impl<I: Interner, T: TypeFoldable<I>> TypeSuperFoldable<I> for Binder<I, T> {
138 fn try_super_fold_with<F: FallibleTypeFolder<I>>(
139 self,
140 folder: &mut F,
141 ) -> Result<Self, F::Error> {
142 self.try_map_bound(|t| t.try_fold_with(folder))
143 }
144
145 fn super_fold_with<F: TypeFolder<I>>(self, folder: &mut F) -> Self {
146 self.map_bound(|t| t.fold_with(folder))
147 }
148}
149
150impl<I: Interner, T: TypeVisitable<I>> TypeSuperVisitable<I> for Binder<I, T> {
151 fn super_visit_with<V: TypeVisitor<I>>(&self, visitor: &mut V) -> V::Result {
152 self.as_ref().skip_binder().visit_with(visitor)
153 }
154}
155
156impl<I: Interner, T> Binder<I, T> {
157 pub fn skip_binder(self) -> T {
171 self.value
172 }
173
174 pub fn bound_vars(&self) -> I::BoundVarKinds {
175 self.bound_vars
176 }
177
178 pub fn as_ref(&self) -> Binder<I, &T> {
179 Binder { value: &self.value, bound_vars: self.bound_vars }
180 }
181
182 pub fn as_deref(&self) -> Binder<I, &T::Target>
183 where
184 T: Deref,
185 {
186 Binder { value: &self.value, bound_vars: self.bound_vars }
187 }
188
189 pub fn map_bound_ref<F, U: TypeVisitable<I>>(&self, f: F) -> Binder<I, U>
190 where
191 F: FnOnce(&T) -> U,
192 {
193 self.as_ref().map_bound(f)
194 }
195
196 pub fn map_bound<F, U: TypeVisitable<I>>(self, f: F) -> Binder<I, U>
197 where
198 F: FnOnce(T) -> U,
199 {
200 let Binder { value, bound_vars } = self;
201 let value = f(value);
202 if truecfg!(debug_assertions) {
203 let mut validator = ValidateBoundVars::new(bound_vars);
204 let _ = value.visit_with(&mut validator);
205 }
206 Binder { value, bound_vars }
207 }
208
209 pub fn try_map_bound<F, U: TypeVisitable<I>, E>(self, f: F) -> Result<Binder<I, U>, E>
210 where
211 F: FnOnce(T) -> Result<U, E>,
212 {
213 let Binder { value, bound_vars } = self;
214 let value = f(value)?;
215 if truecfg!(debug_assertions) {
216 let mut validator = ValidateBoundVars::new(bound_vars);
217 let _ = value.visit_with(&mut validator);
218 }
219 Ok(Binder { value, bound_vars })
220 }
221
222 pub fn rebind<U>(&self, value: U) -> Binder<I, U>
232 where
233 U: TypeVisitable<I>,
234 {
235 Binder::bind_with_vars(value, self.bound_vars)
236 }
237
238 pub fn no_bound_vars(self) -> Option<T>
249 where
250 T: TypeVisitable<I>,
251 {
252 if self.value.has_escaping_bound_vars() { None } else { Some(self.skip_binder()) }
254 }
255}
256
257impl<I: Interner, T> Binder<I, Option<T>> {
258 pub fn transpose(self) -> Option<Binder<I, T>> {
259 let Binder { value, bound_vars } = self;
260 value.map(|value| Binder { value, bound_vars })
261 }
262}
263
264impl<I: Interner, T: IntoIterator> Binder<I, T> {
265 pub fn iter(self) -> impl Iterator<Item = Binder<I, T::Item>> {
266 let Binder { value, bound_vars } = self;
267 value.into_iter().map(move |value| Binder { value, bound_vars })
268 }
269}
270
271pub struct ValidateBoundVars<I: Interner> {
272 bound_vars: I::BoundVarKinds,
273 binder_index: ty::DebruijnIndex,
274 visited: SsoHashSet<(ty::DebruijnIndex, I::Ty)>,
278}
279
280impl<I: Interner> ValidateBoundVars<I> {
281 pub fn new(bound_vars: I::BoundVarKinds) -> Self {
282 ValidateBoundVars {
283 bound_vars,
284 binder_index: ty::INNERMOST,
285 visited: SsoHashSet::default(),
286 }
287 }
288}
289
290impl<I: Interner> TypeVisitor<I> for ValidateBoundVars<I> {
291 type Result = ControlFlow<()>;
292
293 fn visit_binder<T: TypeVisitable<I>>(&mut self, t: &Binder<I, T>) -> Self::Result {
294 self.binder_index.shift_in(1);
295 let result = t.super_visit_with(self);
296 self.binder_index.shift_out(1);
297 result
298 }
299
300 fn visit_ty(&mut self, t: I::Ty) -> Self::Result {
301 if t.outer_exclusive_binder() < self.binder_index
302 || !self.visited.insert((self.binder_index, t))
303 {
304 return ControlFlow::Break(());
305 }
306 match t.kind() {
307 ty::Bound(ty::BoundVarIndexKind::Bound(debruijn), bound_ty)
308 if debruijn == self.binder_index =>
309 {
310 let idx = bound_ty.var().as_usize();
311 if self.bound_vars.len() <= idx {
312 {
::core::panicking::panic_fmt(format_args!("Not enough bound vars: {0:?} not found in {1:?}",
t, self.bound_vars));
};panic!("Not enough bound vars: {:?} not found in {:?}", t, self.bound_vars);
313 }
314 bound_ty.assert_eq(self.bound_vars.get(idx).unwrap());
315 }
316 _ => {}
317 };
318
319 t.super_visit_with(self)
320 }
321
322 fn visit_const(&mut self, c: I::Const) -> Self::Result {
323 if c.outer_exclusive_binder() < self.binder_index {
324 return ControlFlow::Break(());
325 }
326 match c.kind() {
327 ty::ConstKind::Bound(debruijn, bound_const)
328 if debruijn == ty::BoundVarIndexKind::Bound(self.binder_index) =>
329 {
330 let idx = bound_const.var().as_usize();
331 if self.bound_vars.len() <= idx {
332 {
::core::panicking::panic_fmt(format_args!("Not enough bound vars: {0:?} not found in {1:?}",
c, self.bound_vars));
};panic!("Not enough bound vars: {:?} not found in {:?}", c, self.bound_vars);
333 }
334 bound_const.assert_eq(self.bound_vars.get(idx).unwrap());
335 }
336 _ => {}
337 };
338
339 c.super_visit_with(self)
340 }
341
342 fn visit_region(&mut self, r: I::Region) -> Self::Result {
343 match r.kind() {
344 ty::ReBound(index, br) if index == ty::BoundVarIndexKind::Bound(self.binder_index) => {
345 let idx = br.var().as_usize();
346 if self.bound_vars.len() <= idx {
347 {
::core::panicking::panic_fmt(format_args!("Not enough bound vars: {0:?} not found in {1:?}",
r, self.bound_vars));
};panic!("Not enough bound vars: {:?} not found in {:?}", r, self.bound_vars);
348 }
349 br.assert_eq(self.bound_vars.get(idx).unwrap());
350 }
351
352 _ => (),
353 };
354
355 ControlFlow::Continue(())
356 }
357}
358
359#[automatically_derived]
impl<I: Interner, T> ::core::fmt::Debug for EarlyBinder<I, T> where
I: Interner, T: ::core::fmt::Debug {
fn fmt(&self, __f: &mut ::core::fmt::Formatter<'_>)
-> ::core::fmt::Result {
match self {
EarlyBinder { value: ref __field_value, _tcx: ref __field__tcx }
=> {
let mut __builder =
::core::fmt::Formatter::debug_struct(__f, "EarlyBinder");
::core::fmt::DebugStruct::field(&mut __builder, "value",
__field_value);
::core::fmt::DebugStruct::finish_non_exhaustive(&mut __builder)
}
}
}
}#[derive_where(Clone, Copy, PartialOrd, Ord, PartialEq, Hash, Debug; I: Interner, T)]
365#[derive(GenericTypeVisitable)]
366#[cfg_attr(
367 feature = "nightly",
368 derive(const _: () =
{
impl<I: Interner, T, __E: ::rustc_serialize::Encoder>
::rustc_serialize::Encodable<__E> for EarlyBinder<I, T> where
T: ::rustc_serialize::Encodable<__E>,
PhantomData<fn() -> I>: ::rustc_serialize::Encodable<__E> {
fn encode(&self, __encoder: &mut __E) {
match *self {
EarlyBinder { value: ref __binding_0, _tcx: ref __binding_1
} => {
::rustc_serialize::Encodable::<__E>::encode(__binding_0,
__encoder);
::rustc_serialize::Encodable::<__E>::encode(__binding_1,
__encoder);
}
}
}
}
};Encodable_NoContext, const _: () =
{
impl<I: Interner, T, __D: ::rustc_serialize::Decoder>
::rustc_serialize::Decodable<__D> for EarlyBinder<I, T> where
T: ::rustc_serialize::Decodable<__D>,
PhantomData<fn() -> I>: ::rustc_serialize::Decodable<__D> {
fn decode(__decoder: &mut __D) -> Self {
EarlyBinder {
value: ::rustc_serialize::Decodable::decode(__decoder),
_tcx: ::rustc_serialize::Decodable::decode(__decoder),
}
}
}
};Decodable_NoContext, const _: () =
{
impl<I: Interner, T>
::rustc_data_structures::stable_hasher::StableHash for
EarlyBinder<I, T> where
T: ::rustc_data_structures::stable_hasher::StableHash,
PhantomData<fn()
-> I>: ::rustc_data_structures::stable_hasher::StableHash {
#[inline]
fn stable_hash<__Hcx: ::rustc_data_structures::stable_hasher::StableHashCtxt>(&self,
__hcx: &mut __Hcx,
__hasher:
&mut ::rustc_data_structures::stable_hasher::StableHasher) {
match *self {
EarlyBinder { value: ref __binding_0, _tcx: ref __binding_1
} => {
{ __binding_0.stable_hash(__hcx, __hasher); }
{ __binding_1.stable_hash(__hcx, __hasher); }
}
}
}
}
};StableHash_NoContext)
369)]
370pub struct EarlyBinder<I: Interner, T> {
371 value: T,
372 #[derive_where(skip(Debug))]
373 _tcx: PhantomData<fn() -> I>,
374}
375
376impl<I: Interner, T: Eq> Eq for EarlyBinder<I, T> {}
377
378#[cfg(feature = "nightly")]
380macro_rules! generate { ($( $tt:tt )*) => { $( $tt )* } }
381
382#[cfg(feature = "nightly")]
383generate!(
384 impl<I: Interner, T> !TypeFoldable<I> for ty::EarlyBinder<I, T> {}
386 impl<I: Interner, T> !TypeVisitable<I> for ty::EarlyBinder<I, T> {}
388);
389
390impl<I: Interner, T> EarlyBinder<I, T> {
391 pub fn bind(value: T) -> EarlyBinder<I, T> {
392 EarlyBinder { value, _tcx: PhantomData }
393 }
394
395 pub fn as_ref(&self) -> EarlyBinder<I, &T> {
396 EarlyBinder { value: &self.value, _tcx: PhantomData }
397 }
398
399 pub fn map_bound_ref<F, U>(&self, f: F) -> EarlyBinder<I, U>
400 where
401 F: FnOnce(&T) -> U,
402 {
403 self.as_ref().map_bound(f)
404 }
405
406 pub fn map_bound<F, U>(self, f: F) -> EarlyBinder<I, U>
407 where
408 F: FnOnce(T) -> U,
409 {
410 let value = f(self.value);
411 EarlyBinder { value, _tcx: PhantomData }
412 }
413
414 pub fn try_map_bound<F, U, E>(self, f: F) -> Result<EarlyBinder<I, U>, E>
415 where
416 F: FnOnce(T) -> Result<U, E>,
417 {
418 let value = f(self.value)?;
419 Ok(EarlyBinder { value, _tcx: PhantomData })
420 }
421
422 pub fn rebind<U>(&self, value: U) -> EarlyBinder<I, U> {
423 EarlyBinder { value, _tcx: PhantomData }
424 }
425
426 pub fn skip_binder(self) -> T {
443 self.value
444 }
445}
446
447impl<I: Interner, T> EarlyBinder<I, Option<T>> {
448 pub fn transpose(self) -> Option<EarlyBinder<I, T>> {
449 self.value.map(|value| EarlyBinder { value, _tcx: PhantomData })
450 }
451}
452
453impl<I: Interner, Iter: IntoIterator> EarlyBinder<I, Iter>
454where
455 Iter::Item: TypeFoldable<I>,
456{
457 pub fn iter_instantiated<A>(self, cx: I, args: A) -> IterInstantiated<I, Iter, A>
458 where
459 A: SliceLike<Item = I::GenericArg>,
460 {
461 IterInstantiated { it: self.value.into_iter(), cx, args }
462 }
463
464 pub fn iter_identity(self) -> impl Iterator<Item = Unnormalized<I, Iter::Item>> {
467 self.value.into_iter().map(Unnormalized::new)
468 }
469}
470
471pub struct IterInstantiated<I: Interner, Iter: IntoIterator, A> {
472 it: Iter::IntoIter,
473 cx: I,
474 args: A,
475}
476
477impl<I: Interner, Iter: IntoIterator, A> Iterator for IterInstantiated<I, Iter, A>
478where
479 Iter::Item: TypeFoldable<I>,
480 A: SliceLike<Item = I::GenericArg>,
481{
482 type Item = Unnormalized<I, Iter::Item>;
483
484 fn next(&mut self) -> Option<Self::Item> {
485 Some(
486 EarlyBinder { value: self.it.next()?, _tcx: PhantomData }
487 .instantiate(self.cx, self.args),
488 )
489 }
490
491 fn size_hint(&self) -> (usize, Option<usize>) {
492 self.it.size_hint()
493 }
494}
495
496impl<I: Interner, Iter: IntoIterator, A> DoubleEndedIterator for IterInstantiated<I, Iter, A>
497where
498 Iter::IntoIter: DoubleEndedIterator,
499 Iter::Item: TypeFoldable<I>,
500 A: SliceLike<Item = I::GenericArg>,
501{
502 fn next_back(&mut self) -> Option<Self::Item> {
503 Some(
504 EarlyBinder { value: self.it.next_back()?, _tcx: PhantomData }
505 .instantiate(self.cx, self.args),
506 )
507 }
508}
509
510impl<I: Interner, Iter: IntoIterator, A> ExactSizeIterator for IterInstantiated<I, Iter, A>
511where
512 Iter::IntoIter: ExactSizeIterator,
513 Iter::Item: TypeFoldable<I>,
514 A: SliceLike<Item = I::GenericArg>,
515{
516}
517
518impl<'s, I: Interner, Iter: IntoIterator> EarlyBinder<I, Iter>
519where
520 Iter::Item: Deref,
521 <Iter::Item as Deref>::Target: Copy + TypeFoldable<I>,
522{
523 pub fn iter_instantiated_copied(
524 self,
525 cx: I,
526 args: &'s [I::GenericArg],
527 ) -> IterInstantiatedCopied<'s, I, Iter> {
528 IterInstantiatedCopied { it: self.value.into_iter(), cx, args }
529 }
530
531 pub fn iter_identity_copied(self) -> IterIdentityCopied<I, Iter> {
534 IterIdentityCopied { it: self.value.into_iter(), _tcx: PhantomData }
535 }
536}
537
538pub struct IterInstantiatedCopied<'a, I: Interner, Iter: IntoIterator> {
539 it: Iter::IntoIter,
540 cx: I,
541 args: &'a [I::GenericArg],
542}
543
544impl<I: Interner, Iter: IntoIterator> Iterator for IterInstantiatedCopied<'_, I, Iter>
545where
546 Iter::Item: Deref,
547 <Iter::Item as Deref>::Target: Copy + TypeFoldable<I>,
548{
549 type Item = Unnormalized<I, <Iter::Item as Deref>::Target>;
550
551 fn next(&mut self) -> Option<Self::Item> {
552 self.it.next().map(|value| {
553 EarlyBinder { value: *value, _tcx: PhantomData }.instantiate(self.cx, self.args)
554 })
555 }
556
557 fn size_hint(&self) -> (usize, Option<usize>) {
558 self.it.size_hint()
559 }
560}
561
562impl<I: Interner, Iter: IntoIterator> DoubleEndedIterator for IterInstantiatedCopied<'_, I, Iter>
563where
564 Iter::IntoIter: DoubleEndedIterator,
565 Iter::Item: Deref,
566 <Iter::Item as Deref>::Target: Copy + TypeFoldable<I>,
567{
568 fn next_back(&mut self) -> Option<Self::Item> {
569 self.it.next_back().map(|value| {
570 EarlyBinder { value: *value, _tcx: PhantomData }.instantiate(self.cx, self.args)
571 })
572 }
573}
574
575impl<I: Interner, Iter: IntoIterator> ExactSizeIterator for IterInstantiatedCopied<'_, I, Iter>
576where
577 Iter::IntoIter: ExactSizeIterator,
578 Iter::Item: Deref,
579 <Iter::Item as Deref>::Target: Copy + TypeFoldable<I>,
580{
581}
582
583pub struct IterIdentityCopied<I: Interner, Iter: IntoIterator> {
584 it: Iter::IntoIter,
585 _tcx: PhantomData<fn() -> I>,
586}
587
588impl<I: Interner, Iter: IntoIterator> Iterator for IterIdentityCopied<I, Iter>
589where
590 Iter::Item: Deref,
591 <Iter::Item as Deref>::Target: Copy,
592{
593 type Item = Unnormalized<I, <Iter::Item as Deref>::Target>;
594
595 fn next(&mut self) -> Option<Self::Item> {
596 self.it.next().map(|i| Unnormalized::new(*i))
597 }
598
599 fn size_hint(&self) -> (usize, Option<usize>) {
600 self.it.size_hint()
601 }
602}
603
604impl<I: Interner, Iter: IntoIterator> DoubleEndedIterator for IterIdentityCopied<I, Iter>
605where
606 Iter::IntoIter: DoubleEndedIterator,
607 Iter::Item: Deref,
608 <Iter::Item as Deref>::Target: Copy,
609{
610 fn next_back(&mut self) -> Option<Self::Item> {
611 self.it.next_back().map(|i| Unnormalized::new(*i))
612 }
613}
614
615impl<I: Interner, Iter: IntoIterator> ExactSizeIterator for IterIdentityCopied<I, Iter>
616where
617 Iter::IntoIter: ExactSizeIterator,
618 Iter::Item: Deref,
619 <Iter::Item as Deref>::Target: Copy,
620{
621}
622pub struct EarlyBinderIter<I, T> {
623 t: T,
624 _tcx: PhantomData<I>,
625}
626
627impl<I: Interner, T: IntoIterator> EarlyBinder<I, T> {
628 pub fn transpose_iter(self) -> EarlyBinderIter<I, T::IntoIter> {
629 EarlyBinderIter { t: self.value.into_iter(), _tcx: PhantomData }
630 }
631}
632
633impl<I: Interner, T: Iterator> Iterator for EarlyBinderIter<I, T> {
634 type Item = EarlyBinder<I, T::Item>;
635
636 fn next(&mut self) -> Option<Self::Item> {
637 self.t.next().map(|value| EarlyBinder { value, _tcx: PhantomData })
638 }
639
640 fn size_hint(&self) -> (usize, Option<usize>) {
641 self.t.size_hint()
642 }
643}
644
645impl<I: Interner, T: TypeFoldable<I>> ty::EarlyBinder<I, T> {
646 pub fn instantiate<A>(self, cx: I, args: A) -> Unnormalized<I, T>
647 where
648 A: SliceLike<Item = I::GenericArg>,
649 {
650 if args.is_empty() {
654 if !!self.value.has_param() {
{
::core::panicking::panic_fmt(format_args!("{0:?} has parameters, but no args were provided in instantiate",
self.value));
}
};assert!(
655 !self.value.has_param(),
656 "{:?} has parameters, but no args were provided in instantiate",
657 self.value,
658 );
659 return Unnormalized::new(self.value);
660 }
661 let mut folder = ArgFolder { cx, args: args.as_slice(), binders_passed: 0 };
662 Unnormalized::new(self.value.fold_with(&mut folder))
663 }
664
665 pub fn instantiate_identity(self) -> Unnormalized<I, T> {
674 Unnormalized::new(self.value)
683 }
684
685 pub fn no_bound_vars(self) -> Option<T> {
687 if !self.value.has_param() { Some(self.value) } else { None }
688 }
689}
690
691struct ArgFolder<'a, I: Interner> {
695 cx: I,
696 args: &'a [I::GenericArg],
697
698 binders_passed: u32,
700}
701
702impl<'a, I: Interner> TypeFolder<I> for ArgFolder<'a, I> {
703 #[inline]
704 fn cx(&self) -> I {
705 self.cx
706 }
707
708 fn fold_binder<T: TypeFoldable<I>>(&mut self, t: ty::Binder<I, T>) -> ty::Binder<I, T> {
709 self.binders_passed += 1;
710 let t = t.super_fold_with(self);
711 self.binders_passed -= 1;
712 t
713 }
714
715 fn fold_region(&mut self, r: I::Region) -> I::Region {
716 match r.kind() {
722 ty::ReEarlyParam(data) => {
723 let rk = self.args.get(data.index() as usize).map(|arg| arg.kind());
724 match rk {
725 Some(ty::GenericArgKind::Lifetime(lt)) => self.shift_region_through_binders(lt),
726 Some(other) => self.region_param_expected(data, r, other),
727 None => self.region_param_out_of_range(data, r),
728 }
729 }
730 ty::ReBound(..)
731 | ty::ReLateParam(_)
732 | ty::ReStatic
733 | ty::RePlaceholder(_)
734 | ty::ReErased
735 | ty::ReError(_) => r,
736 ty::ReVar(_) => { ::core::panicking::panic_fmt(format_args!("unexpected region: {0:?}", r)); }panic!("unexpected region: {r:?}"),
737 }
738 }
739
740 fn fold_ty(&mut self, t: I::Ty) -> I::Ty {
741 if !t.has_param() {
742 return t;
743 }
744
745 match t.kind() {
746 ty::Param(p) => self.ty_for_param(p, t),
747 _ => t.super_fold_with(self),
748 }
749 }
750
751 fn fold_const(&mut self, c: I::Const) -> I::Const {
752 if let ty::ConstKind::Param(p) = c.kind() {
753 self.const_for_param(p, c)
754 } else {
755 c.super_fold_with(self)
756 }
757 }
758
759 fn fold_predicate(&mut self, p: I::Predicate) -> I::Predicate {
760 if p.has_param() { p.super_fold_with(self) } else { p }
761 }
762
763 fn fold_clauses(&mut self, c: I::Clauses) -> I::Clauses {
764 if c.has_param() { c.super_fold_with(self) } else { c }
765 }
766}
767
768impl<'a, I: Interner> ArgFolder<'a, I> {
769 fn ty_for_param(&self, p: I::ParamTy, source_ty: I::Ty) -> I::Ty {
770 let opt_ty = self.args.get(p.index() as usize).map(|arg| arg.kind());
772 let ty = match opt_ty {
773 Some(ty::GenericArgKind::Type(ty)) => ty,
774 Some(kind) => self.type_param_expected(p, source_ty, kind),
775 None => self.type_param_out_of_range(p, source_ty),
776 };
777
778 self.shift_vars_through_binders(ty)
779 }
780
781 #[cold]
782 #[inline(never)]
783 fn type_param_expected(&self, p: I::ParamTy, ty: I::Ty, kind: ty::GenericArgKind<I>) -> ! {
784 {
::core::panicking::panic_fmt(format_args!("expected type for `{0:?}` ({1:?}/{2}) but found {3:?} when instantiating, args={4:?}",
p, ty, p.index(), kind, self.args));
}panic!(
785 "expected type for `{:?}` ({:?}/{}) but found {:?} when instantiating, args={:?}",
786 p,
787 ty,
788 p.index(),
789 kind,
790 self.args,
791 )
792 }
793
794 #[cold]
795 #[inline(never)]
796 fn type_param_out_of_range(&self, p: I::ParamTy, ty: I::Ty) -> ! {
797 {
::core::panicking::panic_fmt(format_args!("type parameter `{0:?}` ({1:?}/{2}) out of range when instantiating, args={3:?}",
p, ty, p.index(), self.args));
}panic!(
798 "type parameter `{:?}` ({:?}/{}) out of range when instantiating, args={:?}",
799 p,
800 ty,
801 p.index(),
802 self.args,
803 )
804 }
805
806 fn const_for_param(&self, p: I::ParamConst, source_ct: I::Const) -> I::Const {
807 let opt_ct = self.args.get(p.index() as usize).map(|arg| arg.kind());
809 let ct = match opt_ct {
810 Some(ty::GenericArgKind::Const(ct)) => ct,
811 Some(kind) => self.const_param_expected(p, source_ct, kind),
812 None => self.const_param_out_of_range(p, source_ct),
813 };
814
815 self.shift_vars_through_binders(ct)
816 }
817
818 #[cold]
819 #[inline(never)]
820 fn const_param_expected(
821 &self,
822 p: I::ParamConst,
823 ct: I::Const,
824 kind: ty::GenericArgKind<I>,
825 ) -> ! {
826 {
::core::panicking::panic_fmt(format_args!("expected const for `{0:?}` ({1:?}/{2}) but found {3:?} when instantiating args={4:?}",
p, ct, p.index(), kind, self.args));
}panic!(
827 "expected const for `{:?}` ({:?}/{}) but found {:?} when instantiating args={:?}",
828 p,
829 ct,
830 p.index(),
831 kind,
832 self.args,
833 )
834 }
835
836 #[cold]
837 #[inline(never)]
838 fn const_param_out_of_range(&self, p: I::ParamConst, ct: I::Const) -> ! {
839 {
::core::panicking::panic_fmt(format_args!("const parameter `{0:?}` ({1:?}/{2}) out of range when instantiating args={3:?}",
p, ct, p.index(), self.args));
}panic!(
840 "const parameter `{:?}` ({:?}/{}) out of range when instantiating args={:?}",
841 p,
842 ct,
843 p.index(),
844 self.args,
845 )
846 }
847
848 #[cold]
849 #[inline(never)]
850 fn region_param_expected(
851 &self,
852 ebr: I::EarlyParamRegion,
853 r: I::Region,
854 kind: ty::GenericArgKind<I>,
855 ) -> ! {
856 {
::core::panicking::panic_fmt(format_args!("expected region for `{0:?}` ({1:?}/{2}) but found {3:?} when instantiating args={4:?}",
ebr, r, ebr.index(), kind, self.args));
}panic!(
857 "expected region for `{:?}` ({:?}/{}) but found {:?} when instantiating args={:?}",
858 ebr,
859 r,
860 ebr.index(),
861 kind,
862 self.args,
863 )
864 }
865
866 #[cold]
867 #[inline(never)]
868 fn region_param_out_of_range(&self, ebr: I::EarlyParamRegion, r: I::Region) -> ! {
869 {
::core::panicking::panic_fmt(format_args!("region parameter `{0:?}` ({1:?}/{2}) out of range when instantiating args={3:?}",
ebr, r, ebr.index(), self.args));
}panic!(
870 "region parameter `{:?}` ({:?}/{}) out of range when instantiating args={:?}",
871 ebr,
872 r,
873 ebr.index(),
874 self.args,
875 )
876 }
877
878 x;#[instrument(level = "trace", skip(self), fields(binders_passed = self.binders_passed), ret)]
921 fn shift_vars_through_binders<T: TypeFoldable<I>>(&self, val: T) -> T {
922 if self.binders_passed == 0 || !val.has_escaping_bound_vars() {
923 val
924 } else {
925 ty::shift_vars(self.cx, val, self.binders_passed)
926 }
927 }
928
929 fn shift_region_through_binders(&self, region: I::Region) -> I::Region {
930 if self.binders_passed == 0 || !region.has_escaping_bound_vars() {
931 region
932 } else {
933 ty::shift_region(self.cx, region, self.binders_passed)
934 }
935 }
936}
937
938#[derive(#[automatically_derived]
impl ::core::clone::Clone for BoundVarIndexKind {
#[inline]
fn clone(&self) -> BoundVarIndexKind {
let _: ::core::clone::AssertParamIsClone<DebruijnIndex>;
*self
}
}Clone, #[automatically_derived]
impl ::core::marker::Copy for BoundVarIndexKind { }Copy, #[automatically_derived]
impl ::core::fmt::Debug for BoundVarIndexKind {
#[inline]
fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
match self {
BoundVarIndexKind::Bound(__self_0) =>
::core::fmt::Formatter::debug_tuple_field1_finish(f, "Bound",
&__self_0),
BoundVarIndexKind::Canonical =>
::core::fmt::Formatter::write_str(f, "Canonical"),
}
}
}Debug, #[automatically_derived]
impl ::core::cmp::PartialEq for BoundVarIndexKind {
#[inline]
fn eq(&self, other: &BoundVarIndexKind) -> bool {
let __self_discr = ::core::intrinsics::discriminant_value(self);
let __arg1_discr = ::core::intrinsics::discriminant_value(other);
__self_discr == __arg1_discr &&
match (self, other) {
(BoundVarIndexKind::Bound(__self_0),
BoundVarIndexKind::Bound(__arg1_0)) => __self_0 == __arg1_0,
_ => true,
}
}
}PartialEq, #[automatically_derived]
impl ::core::cmp::Eq for BoundVarIndexKind {
#[inline]
#[doc(hidden)]
#[coverage(off)]
fn assert_fields_are_eq(&self) {
let _: ::core::cmp::AssertParamIsEq<DebruijnIndex>;
}
}Eq, #[automatically_derived]
impl ::core::hash::Hash for BoundVarIndexKind {
#[inline]
fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) {
let __self_discr = ::core::intrinsics::discriminant_value(self);
::core::hash::Hash::hash(&__self_discr, state);
match self {
BoundVarIndexKind::Bound(__self_0) =>
::core::hash::Hash::hash(__self_0, state),
_ => {}
}
}
}Hash)]
958#[cfg_attr(feature = "nightly", derive(const _: () =
{
impl<__E: ::rustc_serialize::Encoder>
::rustc_serialize::Encodable<__E> for BoundVarIndexKind {
fn encode(&self, __encoder: &mut __E) {
let disc =
match *self {
BoundVarIndexKind::Bound(ref __binding_0) => { 0usize }
BoundVarIndexKind::Canonical => { 1usize }
};
::rustc_serialize::Encoder::emit_u8(__encoder, disc as u8);
match *self {
BoundVarIndexKind::Bound(ref __binding_0) => {
::rustc_serialize::Encodable::<__E>::encode(__binding_0,
__encoder);
}
BoundVarIndexKind::Canonical => {}
}
}
}
};Encodable_NoContext, const _: () =
{
impl<__D: ::rustc_serialize::Decoder>
::rustc_serialize::Decodable<__D> for BoundVarIndexKind {
fn decode(__decoder: &mut __D) -> Self {
match ::rustc_serialize::Decoder::read_u8(__decoder) as usize
{
0usize => {
BoundVarIndexKind::Bound(::rustc_serialize::Decodable::decode(__decoder))
}
1usize => { BoundVarIndexKind::Canonical }
n => {
::core::panicking::panic_fmt(format_args!("invalid enum variant tag while decoding `BoundVarIndexKind`, expected 0..2, actual {0}",
n));
}
}
}
}
};Decodable_NoContext, const _: () =
{
impl ::rustc_data_structures::stable_hasher::StableHash for
BoundVarIndexKind {
#[inline]
fn stable_hash<__Hcx: ::rustc_data_structures::stable_hasher::StableHashCtxt>(&self,
__hcx: &mut __Hcx,
__hasher:
&mut ::rustc_data_structures::stable_hasher::StableHasher) {
::std::mem::discriminant(self).stable_hash(__hcx, __hasher);
match *self {
BoundVarIndexKind::Bound(ref __binding_0) => {
{ __binding_0.stable_hash(__hcx, __hasher); }
}
BoundVarIndexKind::Canonical => {}
}
}
}
};StableHash))]
959#[derive(const _: () =
{
impl<I> ::rustc_type_ir::TypeVisitable<I> for BoundVarIndexKind where
I: Interner {
fn visit_with<__V: ::rustc_type_ir::TypeVisitor<I>>(&self,
__visitor: &mut __V) -> __V::Result {
match *self {
BoundVarIndexKind::Bound(ref __binding_0) => {
{
match ::rustc_type_ir::VisitorResult::branch(::rustc_type_ir::TypeVisitable::visit_with(__binding_0,
__visitor)) {
::core::ops::ControlFlow::Continue(()) => {}
::core::ops::ControlFlow::Break(r) => {
return ::rustc_type_ir::VisitorResult::from_residual(r);
}
}
}
}
BoundVarIndexKind::Canonical => {}
}
<__V::Result as ::rustc_type_ir::VisitorResult>::output()
}
}
};TypeVisitable_Generic, GenericTypeVisitable, const _: () =
{
impl<I> ::rustc_type_ir::TypeFoldable<I> for BoundVarIndexKind where
I: Interner {
fn try_fold_with<__F: ::rustc_type_ir::FallibleTypeFolder<I>>(self,
__folder: &mut __F) -> Result<Self, __F::Error> {
Ok(match self {
BoundVarIndexKind::Bound(__binding_0) => {
BoundVarIndexKind::Bound(::rustc_type_ir::TypeFoldable::try_fold_with(__binding_0,
__folder)?)
}
BoundVarIndexKind::Canonical => {
BoundVarIndexKind::Canonical
}
})
}
fn fold_with<__F: ::rustc_type_ir::TypeFolder<I>>(self,
__folder: &mut __F) -> Self {
match self {
BoundVarIndexKind::Bound(__binding_0) => {
BoundVarIndexKind::Bound(::rustc_type_ir::TypeFoldable::fold_with(__binding_0,
__folder))
}
BoundVarIndexKind::Canonical => {
BoundVarIndexKind::Canonical
}
}
}
}
};TypeFoldable_Generic)]
960pub enum BoundVarIndexKind {
961 Bound(DebruijnIndex),
962 Canonical,
963}
964
965#[automatically_derived]
impl<I: Interner, T> ::core::hash::Hash for Placeholder<I, T> where
I: Interner, T: ::core::hash::Hash {
fn hash<__H: ::core::hash::Hasher>(&self, __state: &mut __H) {
match self {
Placeholder {
universe: ref __field_universe,
bound: ref __field_bound,
_tcx: ref __field__tcx } => {
::core::hash::Hash::hash(__field_universe, __state);
::core::hash::Hash::hash(__field_bound, __state);
::core::hash::Hash::hash(__field__tcx, __state);
}
}
}
}#[derive_where(Clone, Copy, PartialOrd, Ord, PartialEq, Eq, Hash; I: Interner, T)]
969#[derive(const _: () =
{
impl<I: Interner, T> ::rustc_type_ir::TypeVisitable<I> for
Placeholder<I, T> where I: Interner,
T: ::rustc_type_ir::TypeVisitable<I> {
fn visit_with<__V: ::rustc_type_ir::TypeVisitor<I>>(&self,
__visitor: &mut __V) -> __V::Result {
match *self {
Placeholder {
universe: ref __binding_0, bound: ref __binding_1, .. } => {
{
match ::rustc_type_ir::VisitorResult::branch(::rustc_type_ir::TypeVisitable::visit_with(__binding_0,
__visitor)) {
::core::ops::ControlFlow::Continue(()) => {}
::core::ops::ControlFlow::Break(r) => {
return ::rustc_type_ir::VisitorResult::from_residual(r);
}
}
}
{
match ::rustc_type_ir::VisitorResult::branch(::rustc_type_ir::TypeVisitable::visit_with(__binding_1,
__visitor)) {
::core::ops::ControlFlow::Continue(()) => {}
::core::ops::ControlFlow::Break(r) => {
return ::rustc_type_ir::VisitorResult::from_residual(r);
}
}
}
}
}
<__V::Result as ::rustc_type_ir::VisitorResult>::output()
}
}
};TypeVisitable_Generic, const _: () =
{
impl<I: Interner, T> ::rustc_type_ir::TypeFoldable<I> for
Placeholder<I, T> where I: Interner,
T: ::rustc_type_ir::TypeFoldable<I> {
fn try_fold_with<__F: ::rustc_type_ir::FallibleTypeFolder<I>>(self,
__folder: &mut __F) -> Result<Self, __F::Error> {
Ok(match self {
Placeholder {
universe: __binding_0, bound: __binding_1, _tcx: __binding_2
} => {
Placeholder {
universe: ::rustc_type_ir::TypeFoldable::try_fold_with(__binding_0,
__folder)?,
bound: ::rustc_type_ir::TypeFoldable::try_fold_with(__binding_1,
__folder)?,
_tcx: __binding_2,
}
}
})
}
fn fold_with<__F: ::rustc_type_ir::TypeFolder<I>>(self,
__folder: &mut __F) -> Self {
match self {
Placeholder {
universe: __binding_0, bound: __binding_1, _tcx: __binding_2
} => {
Placeholder {
universe: ::rustc_type_ir::TypeFoldable::fold_with(__binding_0,
__folder),
bound: ::rustc_type_ir::TypeFoldable::fold_with(__binding_1,
__folder),
_tcx: __binding_2,
}
}
}
}
}
};TypeFoldable_Generic, GenericTypeVisitable)]
970#[cfg_attr(
971 feature = "nightly",
972 derive(const _: () =
{
impl<I: Interner, T, __E: ::rustc_serialize::Encoder>
::rustc_serialize::Encodable<__E> for Placeholder<I, T> where
T: ::rustc_serialize::Encodable<__E>,
PhantomData<fn() -> I>: ::rustc_serialize::Encodable<__E> {
fn encode(&self, __encoder: &mut __E) {
match *self {
Placeholder {
universe: ref __binding_0,
bound: ref __binding_1,
_tcx: ref __binding_2 } => {
::rustc_serialize::Encodable::<__E>::encode(__binding_0,
__encoder);
::rustc_serialize::Encodable::<__E>::encode(__binding_1,
__encoder);
::rustc_serialize::Encodable::<__E>::encode(__binding_2,
__encoder);
}
}
}
}
};Encodable_NoContext, const _: () =
{
impl<I: Interner, T, __D: ::rustc_serialize::Decoder>
::rustc_serialize::Decodable<__D> for Placeholder<I, T> where
T: ::rustc_serialize::Decodable<__D>,
PhantomData<fn() -> I>: ::rustc_serialize::Decodable<__D> {
fn decode(__decoder: &mut __D) -> Self {
Placeholder {
universe: ::rustc_serialize::Decodable::decode(__decoder),
bound: ::rustc_serialize::Decodable::decode(__decoder),
_tcx: ::rustc_serialize::Decodable::decode(__decoder),
}
}
}
};Decodable_NoContext, const _: () =
{
impl<I: Interner, T>
::rustc_data_structures::stable_hasher::StableHash for
Placeholder<I, T> where
T: ::rustc_data_structures::stable_hasher::StableHash,
PhantomData<fn()
-> I>: ::rustc_data_structures::stable_hasher::StableHash {
#[inline]
fn stable_hash<__Hcx: ::rustc_data_structures::stable_hasher::StableHashCtxt>(&self,
__hcx: &mut __Hcx,
__hasher:
&mut ::rustc_data_structures::stable_hasher::StableHasher) {
match *self {
Placeholder {
universe: ref __binding_0,
bound: ref __binding_1,
_tcx: ref __binding_2 } => {
{ __binding_0.stable_hash(__hcx, __hasher); }
{ __binding_1.stable_hash(__hcx, __hasher); }
{ __binding_2.stable_hash(__hcx, __hasher); }
}
}
}
}
};StableHash_NoContext)
973)]
974pub struct Placeholder<I: Interner, T> {
975 pub universe: UniverseIndex,
976 pub bound: T,
977 #[type_foldable(identity)]
978 #[type_visitable(ignore)]
979 _tcx: PhantomData<fn() -> I>,
980}
981
982impl<I: Interner, T: fmt::Debug> fmt::Debug for ty::Placeholder<I, T> {
983 fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
984 if self.universe == ty::UniverseIndex::ROOT {
985 f.write_fmt(format_args!("!{0:?}", self.bound))write!(f, "!{:?}", self.bound)
986 } else {
987 f.write_fmt(format_args!("!{0}_{1:?}", self.universe.index(), self.bound))write!(f, "!{}_{:?}", self.universe.index(), self.bound)
988 }
989 }
990}
991
992impl<I: Interner, U: Interner, T> Lift<U> for Placeholder<I, T>
993where
994 T: Lift<U>,
995{
996 type Lifted = Placeholder<U, T::Lifted>;
997
998 fn lift_to_interner(self, cx: U) -> Self::Lifted {
999 Placeholder {
1000 universe: self.universe,
1001 bound: self.bound.lift_to_interner(cx),
1002 _tcx: PhantomData,
1003 }
1004 }
1005}
1006
1007#[automatically_derived]
impl<I: Interner> ::core::hash::Hash for BoundRegionKind<I> where I: Interner
{
fn hash<__H: ::core::hash::Hasher>(&self, __state: &mut __H) {
match self {
BoundRegionKind::Anon => {
::core::hash::Hash::hash(&::core::mem::discriminant(self),
__state);
}
BoundRegionKind::NamedForPrinting(ref __field_0) => {
::core::hash::Hash::hash(&::core::mem::discriminant(self),
__state);
::core::hash::Hash::hash(__field_0, __state);
}
BoundRegionKind::Named(ref __field_0) => {
::core::hash::Hash::hash(&::core::mem::discriminant(self),
__state);
::core::hash::Hash::hash(__field_0, __state);
}
BoundRegionKind::ClosureEnv => {
::core::hash::Hash::hash(&::core::mem::discriminant(self),
__state);
}
}
}
}#[derive_where(Clone, Copy, PartialEq, Eq, Hash; I: Interner)]
1008#[derive(const _: () =
{
impl<I: Interner, J> ::rustc_type_ir::lift::Lift<J> for
BoundRegionKind<I> where I: Interner, J: Interner,
I::Symbol: ::rustc_type_ir::lift::Lift<J, Lifted = J::Symbol>,
I::DefId: ::rustc_type_ir::lift::Lift<J, Lifted = J::DefId> {
type Lifted = BoundRegionKind<J>;
fn lift_to_interner(self, interner: J) -> Self::Lifted {
match self {
BoundRegionKind::Anon => { BoundRegionKind::Anon }
BoundRegionKind::NamedForPrinting(__binding_0) => {
BoundRegionKind::NamedForPrinting(__binding_0.lift_to_interner(interner))
}
BoundRegionKind::Named(__binding_0) => {
BoundRegionKind::Named(__binding_0.lift_to_interner(interner))
}
BoundRegionKind::ClosureEnv => {
BoundRegionKind::ClosureEnv
}
}
}
}
};Lift_Generic, GenericTypeVisitable)]
1009#[cfg_attr(
1010 feature = "nightly",
1011 derive(const _: () =
{
impl<I: Interner, __E: ::rustc_serialize::Encoder>
::rustc_serialize::Encodable<__E> for BoundRegionKind<I> where
I::Symbol: ::rustc_serialize::Encodable<__E>,
I::DefId: ::rustc_serialize::Encodable<__E> {
fn encode(&self, __encoder: &mut __E) {
let disc =
match *self {
BoundRegionKind::Anon => { 0usize }
BoundRegionKind::NamedForPrinting(ref __binding_0) => {
1usize
}
BoundRegionKind::Named(ref __binding_0) => { 2usize }
BoundRegionKind::ClosureEnv => { 3usize }
};
::rustc_serialize::Encoder::emit_u8(__encoder, disc as u8);
match *self {
BoundRegionKind::Anon => {}
BoundRegionKind::NamedForPrinting(ref __binding_0) => {
::rustc_serialize::Encodable::<__E>::encode(__binding_0,
__encoder);
}
BoundRegionKind::Named(ref __binding_0) => {
::rustc_serialize::Encodable::<__E>::encode(__binding_0,
__encoder);
}
BoundRegionKind::ClosureEnv => {}
}
}
}
};Encodable_NoContext, const _: () =
{
impl<I: Interner, __D: ::rustc_serialize::Decoder>
::rustc_serialize::Decodable<__D> for BoundRegionKind<I> where
I::Symbol: ::rustc_serialize::Decodable<__D>,
I::DefId: ::rustc_serialize::Decodable<__D> {
fn decode(__decoder: &mut __D) -> Self {
match ::rustc_serialize::Decoder::read_u8(__decoder) as usize
{
0usize => { BoundRegionKind::Anon }
1usize => {
BoundRegionKind::NamedForPrinting(::rustc_serialize::Decodable::decode(__decoder))
}
2usize => {
BoundRegionKind::Named(::rustc_serialize::Decodable::decode(__decoder))
}
3usize => { BoundRegionKind::ClosureEnv }
n => {
::core::panicking::panic_fmt(format_args!("invalid enum variant tag while decoding `BoundRegionKind`, expected 0..4, actual {0}",
n));
}
}
}
}
};Decodable_NoContext, const _: () =
{
impl<I: Interner> ::rustc_data_structures::stable_hasher::StableHash
for BoundRegionKind<I> where
I::Symbol: ::rustc_data_structures::stable_hasher::StableHash,
I::DefId: ::rustc_data_structures::stable_hasher::StableHash {
#[inline]
fn stable_hash<__Hcx: ::rustc_data_structures::stable_hasher::StableHashCtxt>(&self,
__hcx: &mut __Hcx,
__hasher:
&mut ::rustc_data_structures::stable_hasher::StableHasher) {
::std::mem::discriminant(self).stable_hash(__hcx, __hasher);
match *self {
BoundRegionKind::Anon => {}
BoundRegionKind::NamedForPrinting(ref __binding_0) => {
{ __binding_0.stable_hash(__hcx, __hasher); }
}
BoundRegionKind::Named(ref __binding_0) => {
{ __binding_0.stable_hash(__hcx, __hasher); }
}
BoundRegionKind::ClosureEnv => {}
}
}
}
};StableHash_NoContext)
1012)]
1013pub enum BoundRegionKind<I: Interner> {
1014 Anon,
1016
1017 NamedForPrinting(I::Symbol),
1021
1022 Named(I::DefId),
1024
1025 ClosureEnv,
1028}
1029
1030impl<I: Interner> fmt::Debug for ty::BoundRegionKind<I> {
1031 fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
1032 match *self {
1033 ty::BoundRegionKind::Anon => f.write_fmt(format_args!("BrAnon"))write!(f, "BrAnon"),
1034 ty::BoundRegionKind::NamedForPrinting(name) => {
1035 f.write_fmt(format_args!("BrNamedForPrinting({0:?})", name))write!(f, "BrNamedForPrinting({:?})", name)
1036 }
1037 ty::BoundRegionKind::Named(did) => {
1038 f.write_fmt(format_args!("BrNamed({0:?})", did))write!(f, "BrNamed({did:?})")
1039 }
1040 ty::BoundRegionKind::ClosureEnv => f.write_fmt(format_args!("BrEnv"))write!(f, "BrEnv"),
1041 }
1042 }
1043}
1044
1045impl<I: Interner> BoundRegionKind<I> {
1046 pub fn is_named(&self, tcx: I) -> bool {
1047 self.get_name(tcx).is_some()
1048 }
1049
1050 pub fn get_name(&self, tcx: I) -> Option<I::Symbol> {
1051 match *self {
1052 ty::BoundRegionKind::Named(def_id) => {
1053 let name = tcx.item_name(def_id);
1054 if name.is_kw_underscore_lifetime() { None } else { Some(name) }
1055 }
1056 ty::BoundRegionKind::NamedForPrinting(name) => Some(name),
1057 _ => None,
1058 }
1059 }
1060
1061 pub fn get_id(&self) -> Option<I::DefId> {
1062 match *self {
1063 ty::BoundRegionKind::Named(id) => Some(id),
1064 _ => None,
1065 }
1066 }
1067}
1068
1069#[automatically_derived]
impl<I: Interner> ::core::hash::Hash for BoundTyKind<I> where I: Interner {
fn hash<__H: ::core::hash::Hasher>(&self, __state: &mut __H) {
match self {
BoundTyKind::Anon => {
::core::hash::Hash::hash(&::core::mem::discriminant(self),
__state);
}
BoundTyKind::Param(ref __field_0) => {
::core::hash::Hash::hash(&::core::mem::discriminant(self),
__state);
::core::hash::Hash::hash(__field_0, __state);
}
}
}
}#[derive_where(Clone, Copy, PartialEq, Eq, Debug, Hash; I: Interner)]
1070#[derive(const _: () =
{
impl<I: Interner, J> ::rustc_type_ir::lift::Lift<J> for BoundTyKind<I>
where I: Interner, J: Interner,
I::DefId: ::rustc_type_ir::lift::Lift<J, Lifted = J::DefId> {
type Lifted = BoundTyKind<J>;
fn lift_to_interner(self, interner: J) -> Self::Lifted {
match self {
BoundTyKind::Anon => { BoundTyKind::Anon }
BoundTyKind::Param(__binding_0) => {
BoundTyKind::Param(__binding_0.lift_to_interner(interner))
}
}
}
}
};Lift_Generic, GenericTypeVisitable)]
1071#[cfg_attr(
1072 feature = "nightly",
1073 derive(const _: () =
{
impl<I: Interner, __E: ::rustc_serialize::Encoder>
::rustc_serialize::Encodable<__E> for BoundTyKind<I> where
I::DefId: ::rustc_serialize::Encodable<__E> {
fn encode(&self, __encoder: &mut __E) {
let disc =
match *self {
BoundTyKind::Anon => { 0usize }
BoundTyKind::Param(ref __binding_0) => { 1usize }
};
::rustc_serialize::Encoder::emit_u8(__encoder, disc as u8);
match *self {
BoundTyKind::Anon => {}
BoundTyKind::Param(ref __binding_0) => {
::rustc_serialize::Encodable::<__E>::encode(__binding_0,
__encoder);
}
}
}
}
};Encodable_NoContext, const _: () =
{
impl<I: Interner, __D: ::rustc_serialize::Decoder>
::rustc_serialize::Decodable<__D> for BoundTyKind<I> where
I::DefId: ::rustc_serialize::Decodable<__D> {
fn decode(__decoder: &mut __D) -> Self {
match ::rustc_serialize::Decoder::read_u8(__decoder) as usize
{
0usize => { BoundTyKind::Anon }
1usize => {
BoundTyKind::Param(::rustc_serialize::Decodable::decode(__decoder))
}
n => {
::core::panicking::panic_fmt(format_args!("invalid enum variant tag while decoding `BoundTyKind`, expected 0..2, actual {0}",
n));
}
}
}
}
};Decodable_NoContext, const _: () =
{
impl<I: Interner> ::rustc_data_structures::stable_hasher::StableHash
for BoundTyKind<I> where
I::DefId: ::rustc_data_structures::stable_hasher::StableHash {
#[inline]
fn stable_hash<__Hcx: ::rustc_data_structures::stable_hasher::StableHashCtxt>(&self,
__hcx: &mut __Hcx,
__hasher:
&mut ::rustc_data_structures::stable_hasher::StableHasher) {
::std::mem::discriminant(self).stable_hash(__hcx, __hasher);
match *self {
BoundTyKind::Anon => {}
BoundTyKind::Param(ref __binding_0) => {
{ __binding_0.stable_hash(__hcx, __hasher); }
}
}
}
}
};StableHash_NoContext)
1074)]
1075pub enum BoundTyKind<I: Interner> {
1076 Anon,
1077 Param(I::DefId),
1078}
1079
1080#[automatically_derived]
impl<I: Interner> ::core::hash::Hash for BoundVariableKind<I> where
I: Interner {
fn hash<__H: ::core::hash::Hasher>(&self, __state: &mut __H) {
match self {
BoundVariableKind::Ty(ref __field_0) => {
::core::hash::Hash::hash(&::core::mem::discriminant(self),
__state);
::core::hash::Hash::hash(__field_0, __state);
}
BoundVariableKind::Region(ref __field_0) => {
::core::hash::Hash::hash(&::core::mem::discriminant(self),
__state);
::core::hash::Hash::hash(__field_0, __state);
}
BoundVariableKind::Const => {
::core::hash::Hash::hash(&::core::mem::discriminant(self),
__state);
}
}
}
}#[derive_where(Clone, Copy, PartialEq, Eq, Debug, Hash; I: Interner)]
1081#[derive(const _: () =
{
impl<I: Interner, J> ::rustc_type_ir::lift::Lift<J> for
BoundVariableKind<I> where I: Interner, J: Interner,
BoundTyKind<I>: ::rustc_type_ir::lift::Lift<J, Lifted =
BoundTyKind<J>>,
BoundRegionKind<I>: ::rustc_type_ir::lift::Lift<J, Lifted =
BoundRegionKind<J>> {
type Lifted = BoundVariableKind<J>;
fn lift_to_interner(self, interner: J) -> Self::Lifted {
match self {
BoundVariableKind::Ty(__binding_0) => {
BoundVariableKind::Ty(__binding_0.lift_to_interner(interner))
}
BoundVariableKind::Region(__binding_0) => {
BoundVariableKind::Region(__binding_0.lift_to_interner(interner))
}
BoundVariableKind::Const => { BoundVariableKind::Const }
}
}
}
};Lift_Generic, GenericTypeVisitable)]
1082#[cfg_attr(
1083 feature = "nightly",
1084 derive(const _: () =
{
impl<I: Interner, __E: ::rustc_serialize::Encoder>
::rustc_serialize::Encodable<__E> for BoundVariableKind<I> where
BoundTyKind<I>: ::rustc_serialize::Encodable<__E>,
BoundRegionKind<I>: ::rustc_serialize::Encodable<__E> {
fn encode(&self, __encoder: &mut __E) {
let disc =
match *self {
BoundVariableKind::Ty(ref __binding_0) => { 0usize }
BoundVariableKind::Region(ref __binding_0) => { 1usize }
BoundVariableKind::Const => { 2usize }
};
::rustc_serialize::Encoder::emit_u8(__encoder, disc as u8);
match *self {
BoundVariableKind::Ty(ref __binding_0) => {
::rustc_serialize::Encodable::<__E>::encode(__binding_0,
__encoder);
}
BoundVariableKind::Region(ref __binding_0) => {
::rustc_serialize::Encodable::<__E>::encode(__binding_0,
__encoder);
}
BoundVariableKind::Const => {}
}
}
}
};Encodable_NoContext, const _: () =
{
impl<I: Interner, __D: ::rustc_serialize::Decoder>
::rustc_serialize::Decodable<__D> for BoundVariableKind<I> where
BoundTyKind<I>: ::rustc_serialize::Decodable<__D>,
BoundRegionKind<I>: ::rustc_serialize::Decodable<__D> {
fn decode(__decoder: &mut __D) -> Self {
match ::rustc_serialize::Decoder::read_u8(__decoder) as usize
{
0usize => {
BoundVariableKind::Ty(::rustc_serialize::Decodable::decode(__decoder))
}
1usize => {
BoundVariableKind::Region(::rustc_serialize::Decodable::decode(__decoder))
}
2usize => { BoundVariableKind::Const }
n => {
::core::panicking::panic_fmt(format_args!("invalid enum variant tag while decoding `BoundVariableKind`, expected 0..3, actual {0}",
n));
}
}
}
}
};Decodable_NoContext, const _: () =
{
impl<I: Interner> ::rustc_data_structures::stable_hasher::StableHash
for BoundVariableKind<I> where
BoundTyKind<I>: ::rustc_data_structures::stable_hasher::StableHash,
BoundRegionKind<I>: ::rustc_data_structures::stable_hasher::StableHash
{
#[inline]
fn stable_hash<__Hcx: ::rustc_data_structures::stable_hasher::StableHashCtxt>(&self,
__hcx: &mut __Hcx,
__hasher:
&mut ::rustc_data_structures::stable_hasher::StableHasher) {
::std::mem::discriminant(self).stable_hash(__hcx, __hasher);
match *self {
BoundVariableKind::Ty(ref __binding_0) => {
{ __binding_0.stable_hash(__hcx, __hasher); }
}
BoundVariableKind::Region(ref __binding_0) => {
{ __binding_0.stable_hash(__hcx, __hasher); }
}
BoundVariableKind::Const => {}
}
}
}
};StableHash_NoContext)
1085)]
1086pub enum BoundVariableKind<I: Interner> {
1087 Ty(BoundTyKind<I>),
1088 Region(BoundRegionKind<I>),
1089 Const,
1090}
1091
1092impl<I: Interner> BoundVariableKind<I> {
1093 pub fn expect_region(self) -> BoundRegionKind<I> {
1094 match self {
1095 BoundVariableKind::Region(lt) => lt,
1096 _ => {
::core::panicking::panic_fmt(format_args!("expected a region, but found another kind"));
}panic!("expected a region, but found another kind"),
1097 }
1098 }
1099
1100 pub fn expect_ty(self) -> BoundTyKind<I> {
1101 match self {
1102 BoundVariableKind::Ty(ty) => ty,
1103 _ => {
::core::panicking::panic_fmt(format_args!("expected a type, but found another kind"));
}panic!("expected a type, but found another kind"),
1104 }
1105 }
1106
1107 pub fn expect_const(self) {
1108 match self {
1109 BoundVariableKind::Const => (),
1110 _ => {
::core::panicking::panic_fmt(format_args!("expected a const, but found another kind"));
}panic!("expected a const, but found another kind"),
1111 }
1112 }
1113}
1114
1115#[automatically_derived]
impl<I: Interner> ::core::hash::Hash for BoundRegion<I> where I: Interner {
fn hash<__H: ::core::hash::Hasher>(&self, __state: &mut __H) {
match self {
BoundRegion { var: ref __field_var, kind: ref __field_kind } => {
::core::hash::Hash::hash(__field_var, __state);
::core::hash::Hash::hash(__field_kind, __state);
}
}
}
}#[derive_where(Clone, Copy, PartialEq, Eq, Hash; I: Interner)]
1116#[derive(GenericTypeVisitable)]
1117#[cfg_attr(
1118 feature = "nightly",
1119 derive(const _: () =
{
impl<I: Interner, __E: ::rustc_serialize::Encoder>
::rustc_serialize::Encodable<__E> for BoundRegion<I> where
BoundRegionKind<I>: ::rustc_serialize::Encodable<__E> {
fn encode(&self, __encoder: &mut __E) {
match *self {
BoundRegion { var: ref __binding_0, kind: ref __binding_1 }
=> {
::rustc_serialize::Encodable::<__E>::encode(__binding_0,
__encoder);
::rustc_serialize::Encodable::<__E>::encode(__binding_1,
__encoder);
}
}
}
}
};Encodable_NoContext, const _: () =
{
impl<I: Interner> ::rustc_data_structures::stable_hasher::StableHash
for BoundRegion<I> where
BoundRegionKind<I>: ::rustc_data_structures::stable_hasher::StableHash
{
#[inline]
fn stable_hash<__Hcx: ::rustc_data_structures::stable_hasher::StableHashCtxt>(&self,
__hcx: &mut __Hcx,
__hasher:
&mut ::rustc_data_structures::stable_hasher::StableHasher) {
match *self {
BoundRegion { var: ref __binding_0, kind: ref __binding_1 }
=> {
{ __binding_0.stable_hash(__hcx, __hasher); }
{ __binding_1.stable_hash(__hcx, __hasher); }
}
}
}
}
};StableHash_NoContext, const _: () =
{
impl<I: Interner, __D: ::rustc_serialize::Decoder>
::rustc_serialize::Decodable<__D> for BoundRegion<I> where
BoundRegionKind<I>: ::rustc_serialize::Decodable<__D> {
fn decode(__decoder: &mut __D) -> Self {
BoundRegion {
var: ::rustc_serialize::Decodable::decode(__decoder),
kind: ::rustc_serialize::Decodable::decode(__decoder),
}
}
}
};Decodable_NoContext)
1120)]
1121pub struct BoundRegion<I: Interner> {
1122 pub var: ty::BoundVar,
1123 pub kind: BoundRegionKind<I>,
1124}
1125
1126impl<I: Interner> core::fmt::Debug for BoundRegion<I> {
1127 fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
1128 match self.kind {
1129 BoundRegionKind::Anon => f.write_fmt(format_args!("{0:?}", self.var))write!(f, "{:?}", self.var),
1130 BoundRegionKind::ClosureEnv => f.write_fmt(format_args!("{0:?}.Env", self.var))write!(f, "{:?}.Env", self.var),
1131 BoundRegionKind::Named(def) => {
1132 f.write_fmt(format_args!("{0:?}.Named({1:?})", self.var, def))write!(f, "{:?}.Named({:?})", self.var, def)
1133 }
1134 BoundRegionKind::NamedForPrinting(symbol) => {
1135 f.write_fmt(format_args!("{0:?}.NamedAnon({1:?})", self.var, symbol))write!(f, "{:?}.NamedAnon({:?})", self.var, symbol)
1136 }
1137 }
1138 }
1139}
1140
1141impl<I: Interner> BoundRegion<I> {
1142 pub fn var(self) -> ty::BoundVar {
1143 self.var
1144 }
1145
1146 pub fn assert_eq(self, var: BoundVariableKind<I>) {
1147 match (&self.kind, &var.expect_region()) {
(left_val, right_val) => {
if !(*left_val == *right_val) {
let kind = ::core::panicking::AssertKind::Eq;
::core::panicking::assert_failed(kind, &*left_val, &*right_val,
::core::option::Option::None);
}
}
}assert_eq!(self.kind, var.expect_region())
1148 }
1149}
1150
1151pub type PlaceholderRegion<I> = ty::Placeholder<I, BoundRegion<I>>;
1152
1153impl<I: Interner> PlaceholderRegion<I> {
1154 pub fn universe(self) -> UniverseIndex {
1155 self.universe
1156 }
1157
1158 pub fn var(self) -> ty::BoundVar {
1159 self.bound.var()
1160 }
1161
1162 pub fn with_updated_universe(self, ui: UniverseIndex) -> Self {
1163 Self { universe: ui, bound: self.bound, _tcx: PhantomData }
1164 }
1165
1166 pub fn new(ui: UniverseIndex, bound: BoundRegion<I>) -> Self {
1167 Self { universe: ui, bound, _tcx: PhantomData }
1168 }
1169
1170 pub fn new_anon(ui: UniverseIndex, var: ty::BoundVar) -> Self {
1171 let bound = BoundRegion { var, kind: BoundRegionKind::Anon };
1172 Self { universe: ui, bound, _tcx: PhantomData }
1173 }
1174}
1175
1176#[automatically_derived]
impl<I: Interner> ::core::hash::Hash for BoundTy<I> where I: Interner {
fn hash<__H: ::core::hash::Hasher>(&self, __state: &mut __H) {
match self {
BoundTy { var: ref __field_var, kind: ref __field_kind } => {
::core::hash::Hash::hash(__field_var, __state);
::core::hash::Hash::hash(__field_kind, __state);
}
}
}
}#[derive_where(Clone, Copy, PartialEq, Eq, Hash; I: Interner)]
1177#[derive(GenericTypeVisitable)]
1178#[cfg_attr(
1179 feature = "nightly",
1180 derive(const _: () =
{
impl<I: Interner, __E: ::rustc_serialize::Encoder>
::rustc_serialize::Encodable<__E> for BoundTy<I> where
BoundTyKind<I>: ::rustc_serialize::Encodable<__E> {
fn encode(&self, __encoder: &mut __E) {
match *self {
BoundTy { var: ref __binding_0, kind: ref __binding_1 } => {
::rustc_serialize::Encodable::<__E>::encode(__binding_0,
__encoder);
::rustc_serialize::Encodable::<__E>::encode(__binding_1,
__encoder);
}
}
}
}
};Encodable_NoContext, const _: () =
{
impl<I: Interner, __D: ::rustc_serialize::Decoder>
::rustc_serialize::Decodable<__D> for BoundTy<I> where
BoundTyKind<I>: ::rustc_serialize::Decodable<__D> {
fn decode(__decoder: &mut __D) -> Self {
BoundTy {
var: ::rustc_serialize::Decodable::decode(__decoder),
kind: ::rustc_serialize::Decodable::decode(__decoder),
}
}
}
};Decodable_NoContext, const _: () =
{
impl<I: Interner> ::rustc_data_structures::stable_hasher::StableHash
for BoundTy<I> where
BoundTyKind<I>: ::rustc_data_structures::stable_hasher::StableHash
{
#[inline]
fn stable_hash<__Hcx: ::rustc_data_structures::stable_hasher::StableHashCtxt>(&self,
__hcx: &mut __Hcx,
__hasher:
&mut ::rustc_data_structures::stable_hasher::StableHasher) {
match *self {
BoundTy { var: ref __binding_0, kind: ref __binding_1 } => {
{ __binding_0.stable_hash(__hcx, __hasher); }
{ __binding_1.stable_hash(__hcx, __hasher); }
}
}
}
}
};StableHash_NoContext)
1181)]
1182pub struct BoundTy<I: Interner> {
1183 pub var: ty::BoundVar,
1184 pub kind: BoundTyKind<I>,
1185}
1186
1187impl<I: Interner, U: Interner> Lift<U> for BoundTy<I>
1188where
1189 BoundTyKind<I>: Lift<U, Lifted = BoundTyKind<U>>,
1190{
1191 type Lifted = BoundTy<U>;
1192
1193 fn lift_to_interner(self, cx: U) -> Self::Lifted {
1194 BoundTy { var: self.var, kind: self.kind.lift_to_interner(cx) }
1195 }
1196}
1197
1198impl<I: Interner> fmt::Debug for ty::BoundTy<I> {
1199 fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
1200 match self.kind {
1201 ty::BoundTyKind::Anon => f.write_fmt(format_args!("{0:?}", self.var))write!(f, "{:?}", self.var),
1202 ty::BoundTyKind::Param(def_id) => f.write_fmt(format_args!("{0:?}", def_id))write!(f, "{def_id:?}"),
1203 }
1204 }
1205}
1206
1207impl<I: Interner> BoundTy<I> {
1208 pub fn var(self) -> ty::BoundVar {
1209 self.var
1210 }
1211
1212 pub fn assert_eq(self, var: BoundVariableKind<I>) {
1213 match (&self.kind, &var.expect_ty()) {
(left_val, right_val) => {
if !(*left_val == *right_val) {
let kind = ::core::panicking::AssertKind::Eq;
::core::panicking::assert_failed(kind, &*left_val, &*right_val,
::core::option::Option::None);
}
}
}assert_eq!(self.kind, var.expect_ty())
1214 }
1215}
1216
1217pub type PlaceholderType<I> = ty::Placeholder<I, BoundTy<I>>;
1218
1219impl<I: Interner> PlaceholderType<I> {
1220 pub fn universe(self) -> UniverseIndex {
1221 self.universe
1222 }
1223
1224 pub fn var(self) -> ty::BoundVar {
1225 self.bound.var
1226 }
1227
1228 pub fn with_updated_universe(self, ui: UniverseIndex) -> Self {
1229 Self { universe: ui, bound: self.bound, _tcx: PhantomData }
1230 }
1231
1232 pub fn new(ui: UniverseIndex, bound: BoundTy<I>) -> Self {
1233 Self { universe: ui, bound, _tcx: PhantomData }
1234 }
1235
1236 pub fn new_anon(ui: UniverseIndex, var: ty::BoundVar) -> Self {
1237 let bound = BoundTy { var, kind: BoundTyKind::Anon };
1238 Self { universe: ui, bound, _tcx: PhantomData }
1239 }
1240}
1241
1242#[automatically_derived]
impl<I: Interner> ::core::hash::Hash for BoundConst<I> where I: Interner {
fn hash<__H: ::core::hash::Hasher>(&self, __state: &mut __H) {
match self {
BoundConst { var: ref __field_var, _tcx: ref __field__tcx } => {
::core::hash::Hash::hash(__field_var, __state);
::core::hash::Hash::hash(__field__tcx, __state);
}
}
}
}#[derive_where(Clone, Copy, PartialEq, Debug, Eq, Hash; I: Interner)]
1243#[derive(GenericTypeVisitable)]
1244#[cfg_attr(
1245 feature = "nightly",
1246 derive(const _: () =
{
impl<I: Interner, __E: ::rustc_serialize::Encoder>
::rustc_serialize::Encodable<__E> for BoundConst<I> where
PhantomData<fn() -> I>: ::rustc_serialize::Encodable<__E> {
fn encode(&self, __encoder: &mut __E) {
match *self {
BoundConst { var: ref __binding_0, _tcx: ref __binding_1 }
=> {
::rustc_serialize::Encodable::<__E>::encode(__binding_0,
__encoder);
::rustc_serialize::Encodable::<__E>::encode(__binding_1,
__encoder);
}
}
}
}
};Encodable_NoContext, const _: () =
{
impl<I: Interner, __D: ::rustc_serialize::Decoder>
::rustc_serialize::Decodable<__D> for BoundConst<I> where
PhantomData<fn() -> I>: ::rustc_serialize::Decodable<__D> {
fn decode(__decoder: &mut __D) -> Self {
BoundConst {
var: ::rustc_serialize::Decodable::decode(__decoder),
_tcx: ::rustc_serialize::Decodable::decode(__decoder),
}
}
}
};Decodable_NoContext, const _: () =
{
impl<I: Interner> ::rustc_data_structures::stable_hasher::StableHash
for BoundConst<I> where
PhantomData<fn()
-> I>: ::rustc_data_structures::stable_hasher::StableHash {
#[inline]
fn stable_hash<__Hcx: ::rustc_data_structures::stable_hasher::StableHashCtxt>(&self,
__hcx: &mut __Hcx,
__hasher:
&mut ::rustc_data_structures::stable_hasher::StableHasher) {
match *self {
BoundConst { var: ref __binding_0, _tcx: ref __binding_1 }
=> {
{ __binding_0.stable_hash(__hcx, __hasher); }
{ __binding_1.stable_hash(__hcx, __hasher); }
}
}
}
}
};StableHash_NoContext)
1247)]
1248pub struct BoundConst<I: Interner> {
1249 pub var: ty::BoundVar,
1250 #[derive_where(skip(Debug))]
1251 pub _tcx: PhantomData<fn() -> I>,
1252}
1253
1254impl<I: Interner> BoundConst<I> {
1255 pub fn var(self) -> ty::BoundVar {
1256 self.var
1257 }
1258
1259 pub fn assert_eq(self, var: BoundVariableKind<I>) {
1260 var.expect_const()
1261 }
1262
1263 pub fn new(var: ty::BoundVar) -> Self {
1264 Self { var, _tcx: PhantomData }
1265 }
1266}
1267
1268pub type PlaceholderConst<I> = ty::Placeholder<I, BoundConst<I>>;
1269
1270impl<I: Interner> PlaceholderConst<I> {
1271 pub fn universe(self) -> UniverseIndex {
1272 self.universe
1273 }
1274
1275 pub fn var(self) -> ty::BoundVar {
1276 self.bound.var
1277 }
1278
1279 pub fn with_updated_universe(self, ui: UniverseIndex) -> Self {
1280 Self { universe: ui, bound: self.bound, _tcx: PhantomData }
1281 }
1282
1283 pub fn new(ui: UniverseIndex, bound: BoundConst<I>) -> Self {
1284 Self { universe: ui, bound, _tcx: PhantomData }
1285 }
1286
1287 pub fn new_anon(ui: UniverseIndex, var: ty::BoundVar) -> Self {
1288 let bound = BoundConst::new(var);
1289 Self { universe: ui, bound, _tcx: PhantomData }
1290 }
1291
1292 pub fn find_const_ty_from_env(self, env: I::ParamEnv) -> I::Ty {
1293 let mut candidates = env.caller_bounds().iter().filter_map(|clause| {
1294 match clause.kind().skip_binder() {
1296 ty::ClauseKind::ConstArgHasType(placeholder_ct, ty) => {
1297 if !!(placeholder_ct, ty).has_escaping_bound_vars() {
::core::panicking::panic("assertion failed: !(placeholder_ct, ty).has_escaping_bound_vars()")
};assert!(!(placeholder_ct, ty).has_escaping_bound_vars());
1298
1299 match placeholder_ct.kind() {
1300 ty::ConstKind::Placeholder(placeholder_ct) if placeholder_ct == self => {
1301 Some(ty)
1302 }
1303 _ => None,
1304 }
1305 }
1306 _ => None,
1307 }
1308 });
1309
1310 let ty = candidates.next().unwrap_or_else(|| {
1317 {
::core::panicking::panic_fmt(format_args!("cannot find `{0:?}` in param-env: {1:#?}",
self, env));
};panic!("cannot find `{self:?}` in param-env: {env:#?}");
1318 });
1319 if !candidates.next().is_none() {
{
::core::panicking::panic_fmt(format_args!("did not expect duplicate `ConstParamHasTy` for `{0:?}` in param-env: {1:#?}",
self, env));
}
};assert!(
1320 candidates.next().is_none(),
1321 "did not expect duplicate `ConstParamHasTy` for `{self:?}` in param-env: {env:#?}"
1322 );
1323 ty
1324 }
1325}