1 use pin_project::pin_project;
2 # [pin (__private (project_ref = ProjRef))]
3 struct TupleStruct<T, U>(#[pin] T, U);
4 #[allow(box_pointers)]
5 #[allow(deprecated)]
6 #[allow(explicit_outlives_requirements)]
7 #[allow(single_use_lifetimes)]
8 #[allow(unreachable_pub)]
9 #[allow(clippy::unknown_clippy_lints)]
10 #[allow(clippy::pattern_type_mismatch)]
11 #[allow(clippy::redundant_pub_crate)]
12 #[allow(clippy::type_repetition_in_bounds)]
13 #[allow(dead_code)]
14 #[allow(clippy::ref_option_ref)]
15 struct ProjRef<'pin, T, U>(::pin_project::__private::Pin<&'pin (T)>, &'pin (U))
16 where
17 TupleStruct<T, U>: 'pin;
18 #[allow(box_pointers)]
19 #[allow(deprecated)]
20 #[allow(explicit_outlives_requirements)]
21 #[allow(single_use_lifetimes)]
22 #[allow(unreachable_pub)]
23 #[allow(clippy::unknown_clippy_lints)]
24 #[allow(clippy::pattern_type_mismatch)]
25 #[allow(clippy::redundant_pub_crate)]
26 #[allow(clippy::type_repetition_in_bounds)]
27 #[allow(unused_qualifications)]
28 #[allow(clippy::semicolon_if_nothing_returned)]
29 #[allow(clippy::use_self)]
30 #[allow(clippy::used_underscore_binding)]
31 const _: () = {
32 #[allow(unused_extern_crates)]
33 extern crate pin_project as _pin_project;
34 #[allow(dead_code)]
35 #[allow(clippy::mut_mut)]
36 struct __TupleStructProjection<'pin, T, U>(
37 ::pin_project::__private::Pin<&'pin mut (T)>,
38 &'pin mut (U),
39 )
40 where
41 TupleStruct<T, U>: 'pin;
42 impl<T, U> TupleStruct<T, U> {
project<'pin>( self: _pin_project::__private::Pin<&'pin mut Self>, ) -> __TupleStructProjection<'pin, T, U>43 fn project<'pin>(
44 self: _pin_project::__private::Pin<&'pin mut Self>,
45 ) -> __TupleStructProjection<'pin, T, U> {
46 unsafe {
47 let Self(_0, _1) = self.get_unchecked_mut();
48 __TupleStructProjection(_pin_project::__private::Pin::new_unchecked(_0), _1)
49 }
50 }
51 #[allow(clippy::missing_const_for_fn)]
project_ref<'pin>( self: _pin_project::__private::Pin<&'pin Self>, ) -> ProjRef<'pin, T, U>52 fn project_ref<'pin>(
53 self: _pin_project::__private::Pin<&'pin Self>,
54 ) -> ProjRef<'pin, T, U> {
55 unsafe {
56 let Self(_0, _1) = self.get_ref();
57 ProjRef(_pin_project::__private::Pin::new_unchecked(_0), _1)
58 }
59 }
60 }
61 #[forbid(unaligned_references, safe_packed_borrows)]
__assert_not_repr_packed<T, U>(this: &TupleStruct<T, U>)62 fn __assert_not_repr_packed<T, U>(this: &TupleStruct<T, U>) {
63 let _ = &this.0;
64 let _ = &this.1;
65 }
66 #[allow(missing_debug_implementations)]
67 struct __TupleStruct<'pin, T, U> {
68 __pin_project_use_generics: _pin_project::__private::AlwaysUnpin<
69 'pin,
70 (
71 _pin_project::__private::PhantomData<T>,
72 _pin_project::__private::PhantomData<U>,
73 ),
74 >,
75 __field0: T,
76 }
77 impl<'pin, T, U> _pin_project::__private::Unpin for TupleStruct<T, U> where
78 __TupleStruct<'pin, T, U>: _pin_project::__private::Unpin
79 {
80 }
81 #[doc(hidden)]
82 unsafe impl<'pin, T, U> _pin_project::UnsafeUnpin for TupleStruct<T, U> where
83 __TupleStruct<'pin, T, U>: _pin_project::__private::Unpin
84 {
85 }
86 trait TupleStructMustNotImplDrop {}
87 #[allow(clippy::drop_bounds, drop_bounds)]
88 impl<T: _pin_project::__private::Drop> TupleStructMustNotImplDrop for T {}
89 impl<T, U> TupleStructMustNotImplDrop for TupleStruct<T, U> {}
90 #[doc(hidden)]
91 impl<T, U> _pin_project::__private::PinnedDrop for TupleStruct<T, U> {
drop(self: _pin_project::__private::Pin<&mut Self>)92 unsafe fn drop(self: _pin_project::__private::Pin<&mut Self>) {}
93 }
94 };
main()95 fn main() {}
96