@@ -11,8 +11,14 @@ unsafe extern "C" fn _Unwind_Resume() {
11
11
intrinsics:: unreachable ( ) ;
12
12
}
13
13
14
+ #[ lang = "pointee_sized" ]
15
+ pub trait PointeeSized { }
16
+
17
+ #[ lang = "meta_sized" ]
18
+ pub trait MetaSized : PointeeSized { }
19
+
14
20
#[ lang = "sized" ]
15
- pub trait Sized { }
21
+ pub trait Sized : MetaSized { }
16
22
17
23
#[ lang = "destruct" ]
18
24
pub trait Destruct { }
@@ -21,35 +27,35 @@ pub trait Destruct {}
21
27
pub trait Tuple { }
22
28
23
29
#[ lang = "unsize" ]
24
- pub trait Unsize < T : ? Sized > { }
30
+ pub trait Unsize < T : PointeeSized > : PointeeSized { }
25
31
26
32
#[ lang = "coerce_unsized" ]
27
33
pub trait CoerceUnsized < T > { }
28
34
29
- impl < ' a , ' b : ' a , T : ? Sized + Unsize < U > , U : ? Sized > CoerceUnsized < & ' a U > for & ' b T { }
30
- impl < ' a , T : ? Sized + Unsize < U > , U : ? Sized > CoerceUnsized < & ' a mut U > for & ' a mut T { }
31
- impl < T : ? Sized + Unsize < U > , U : ? Sized > CoerceUnsized < * const U > for * const T { }
32
- impl < T : ? Sized + Unsize < U > , U : ? Sized > CoerceUnsized < * mut U > for * mut T { }
35
+ impl < ' a , ' b : ' a , T : PointeeSized + Unsize < U > , U : PointeeSized > CoerceUnsized < & ' a U > for & ' b T { }
36
+ impl < ' a , T : PointeeSized + Unsize < U > , U : PointeeSized > CoerceUnsized < & ' a mut U > for & ' a mut T { }
37
+ impl < T : PointeeSized + Unsize < U > , U : PointeeSized > CoerceUnsized < * const U > for * const T { }
38
+ impl < T : PointeeSized + Unsize < U > , U : PointeeSized > CoerceUnsized < * mut U > for * mut T { }
33
39
34
40
#[ lang = "dispatch_from_dyn" ]
35
41
pub trait DispatchFromDyn < T > { }
36
42
37
43
// &T -> &U
38
- impl < ' a , T : ? Sized + Unsize < U > , U : ? Sized > DispatchFromDyn < & ' a U > for & ' a T { }
44
+ impl < ' a , T : PointeeSized + Unsize < U > , U : PointeeSized > DispatchFromDyn < & ' a U > for & ' a T { }
39
45
// &mut T -> &mut U
40
- impl < ' a , T : ? Sized + Unsize < U > , U : ? Sized > DispatchFromDyn < & ' a mut U > for & ' a mut T { }
46
+ impl < ' a , T : PointeeSized + Unsize < U > , U : PointeeSized > DispatchFromDyn < & ' a mut U > for & ' a mut T { }
41
47
// *const T -> *const U
42
- impl < T : ? Sized + Unsize < U > , U : ? Sized > DispatchFromDyn < * const U > for * const T { }
48
+ impl < T : PointeeSized + Unsize < U > , U : PointeeSized > DispatchFromDyn < * const U > for * const T { }
43
49
// *mut T -> *mut U
44
- impl < T : ? Sized + Unsize < U > , U : ? Sized > DispatchFromDyn < * mut U > for * mut T { }
45
- impl < T : ? Sized + Unsize < U > , U : ? Sized > DispatchFromDyn < Box < U , ( ) > > for Box < T , ( ) > { }
50
+ impl < T : PointeeSized + Unsize < U > , U : PointeeSized > DispatchFromDyn < * mut U > for * mut T { }
51
+ impl < T : MetaSized + Unsize < U > , U : MetaSized > DispatchFromDyn < Box < U , ( ) > > for Box < T , ( ) > { }
46
52
47
53
#[ lang = "legacy_receiver" ]
48
54
pub trait LegacyReceiver { }
49
55
50
- impl < T : ? Sized > LegacyReceiver for & T { }
51
- impl < T : ? Sized > LegacyReceiver for & mut T { }
52
- impl < T : ? Sized , A : Allocator > LegacyReceiver for Box < T , A > { }
56
+ impl < T : PointeeSized > LegacyReceiver for & T { }
57
+ impl < T : PointeeSized > LegacyReceiver for & mut T { }
58
+ impl < T : MetaSized > LegacyReceiver for Box < T > { }
53
59
54
60
#[ lang = "copy" ]
55
61
pub trait Copy { }
@@ -70,9 +76,9 @@ impl Copy for isize {}
70
76
impl Copy for f32 { }
71
77
impl Copy for f64 { }
72
78
impl Copy for char { }
73
- impl < ' a , T : ? Sized > Copy for & ' a T { }
74
- impl < T : ? Sized > Copy for * const T { }
75
- impl < T : ? Sized > Copy for * mut T { }
79
+ impl < ' a , T : PointeeSized > Copy for & ' a T { }
80
+ impl < T : PointeeSized > Copy for * const T { }
81
+ impl < T : PointeeSized > Copy for * mut T { }
76
82
77
83
#[ lang = "sync" ]
78
84
pub unsafe trait Sync { }
@@ -88,17 +94,17 @@ unsafe impl Sync for i16 {}
88
94
unsafe impl Sync for i32 { }
89
95
unsafe impl Sync for isize { }
90
96
unsafe impl Sync for char { }
91
- unsafe impl < ' a , T : ? Sized > Sync for & ' a T { }
97
+ unsafe impl < ' a , T : PointeeSized > Sync for & ' a T { }
92
98
unsafe impl Sync for [ u8 ; 16 ] { }
93
99
94
100
#[ lang = "freeze" ]
95
101
unsafe auto trait Freeze { }
96
102
97
- unsafe impl < T : ? Sized > Freeze for PhantomData < T > { }
98
- unsafe impl < T : ? Sized > Freeze for * const T { }
99
- unsafe impl < T : ? Sized > Freeze for * mut T { }
100
- unsafe impl < T : ? Sized > Freeze for & T { }
101
- unsafe impl < T : ? Sized > Freeze for & mut T { }
103
+ unsafe impl < T : PointeeSized > Freeze for PhantomData < T > { }
104
+ unsafe impl < T : PointeeSized > Freeze for * const T { }
105
+ unsafe impl < T : PointeeSized > Freeze for * mut T { }
106
+ unsafe impl < T : PointeeSized > Freeze for & T { }
107
+ unsafe impl < T : PointeeSized > Freeze for & mut T { }
102
108
103
109
#[ lang = "structural_peq" ]
104
110
pub trait StructuralPartialEq { }
@@ -403,7 +409,7 @@ pub enum Option<T> {
403
409
pub use Option :: * ;
404
410
405
411
#[ lang = "phantom_data" ]
406
- pub struct PhantomData < T : ? Sized > ;
412
+ pub struct PhantomData < T : PointeeSized > ;
407
413
408
414
#[ lang = "fn_once" ]
409
415
#[ rustc_paren_sugar]
@@ -520,18 +526,18 @@ impl Allocator for Global {}
520
526
#[ repr( transparent) ]
521
527
#[ rustc_layout_scalar_valid_range_start( 1 ) ]
522
528
#[ rustc_nonnull_optimization_guaranteed]
523
- pub struct NonNull < T : ? Sized > ( pub * const T ) ;
529
+ pub struct NonNull < T : PointeeSized > ( pub * const T ) ;
524
530
525
- impl < T : ? Sized , U : ? Sized > CoerceUnsized < NonNull < U > > for NonNull < T > where T : Unsize < U > { }
526
- impl < T : ? Sized , U : ? Sized > DispatchFromDyn < NonNull < U > > for NonNull < T > where T : Unsize < U > { }
531
+ impl < T : PointeeSized , U : PointeeSized > CoerceUnsized < NonNull < U > > for NonNull < T > where T : Unsize < U > { }
532
+ impl < T : PointeeSized , U : PointeeSized > DispatchFromDyn < NonNull < U > > for NonNull < T > where T : Unsize < U > { }
527
533
528
- pub struct Unique < T : ? Sized > {
534
+ pub struct Unique < T : PointeeSized > {
529
535
pub pointer : NonNull < T > ,
530
536
pub _marker : PhantomData < T > ,
531
537
}
532
538
533
- impl < T : ? Sized , U : ? Sized > CoerceUnsized < Unique < U > > for Unique < T > where T : Unsize < U > { }
534
- impl < T : ? Sized , U : ? Sized > DispatchFromDyn < Unique < U > > for Unique < T > where T : Unsize < U > { }
539
+ impl < T : PointeeSized , U : PointeeSized > CoerceUnsized < Unique < U > > for Unique < T > where T : Unsize < U > { }
540
+ impl < T : PointeeSized , U : PointeeSized > DispatchFromDyn < Unique < U > > for Unique < T > where T : Unsize < U > { }
535
541
536
542
#[ lang = "owned_box" ]
537
543
pub struct Box < T : ?Sized , A : Allocator = Global > ( Unique < T > , A ) ;
0 commit comments