2021-05-13 10:42:25 -04:00
|
|
|
// revisions: mirunsafeck thirunsafeck
|
|
|
|
// [thirunsafeck]compile-flags: -Z thir-unsafeck
|
|
|
|
|
2020-08-16 10:07:33 +02:00
|
|
|
//! Test the part of RFC 2514 that is about not applying `DerefMut` coercions
|
|
|
|
//! of union fields.
|
|
|
|
|
|
|
|
use std::mem::ManuallyDrop;
|
|
|
|
|
2020-08-16 10:24:10 +02:00
|
|
|
union U1<T> { x:(), f: ManuallyDrop<(T,)> }
|
|
|
|
|
|
|
|
union U2<T> { x:(), f: (ManuallyDrop<(T,)>,) }
|
2020-08-16 10:07:33 +02:00
|
|
|
|
|
|
|
fn main() {
|
2020-08-16 10:24:10 +02:00
|
|
|
let mut u : U1<Vec<i32>> = U1 { x: () };
|
2020-08-16 10:07:33 +02:00
|
|
|
unsafe { (*u.f).0 = Vec::new() }; // explicit deref, this compiles
|
2020-08-16 10:32:37 +02:00
|
|
|
unsafe { u.f.0 = Vec::new() }; //~ERROR not automatically applying `DerefMut` on `ManuallyDrop` union field
|
2020-08-30 19:12:36 +02:00
|
|
|
unsafe { &mut (*u.f).0 }; // explicit deref, this compiles
|
|
|
|
unsafe { &mut u.f.0 }; //~ERROR not automatically applying `DerefMut` on `ManuallyDrop` union field
|
|
|
|
unsafe { (*u.f).0.push(0) }; // explicit deref, this compiles
|
|
|
|
unsafe { u.f.0.push(0) }; //~ERROR not automatically applying `DerefMut` on `ManuallyDrop` union field
|
2020-08-16 10:24:10 +02:00
|
|
|
|
|
|
|
let mut u : U2<Vec<i32>> = U2 { x: () };
|
|
|
|
unsafe { (*u.f.0).0 = Vec::new() }; // explicit deref, this compiles
|
2020-08-16 10:32:37 +02:00
|
|
|
unsafe { u.f.0.0 = Vec::new() }; //~ERROR not automatically applying `DerefMut` on `ManuallyDrop` union field
|
2020-08-30 19:12:36 +02:00
|
|
|
unsafe { &mut (*u.f.0).0 }; // explicit deref, this compiles
|
|
|
|
unsafe { &mut u.f.0.0 }; //~ERROR not automatically applying `DerefMut` on `ManuallyDrop` union field
|
|
|
|
unsafe { (*u.f.0).0.push(0) }; // explicit deref, this compiles
|
|
|
|
unsafe { u.f.0.0.push(0) }; //~ERROR not automatically applying `DerefMut` on `ManuallyDrop` union field
|
2020-08-16 10:07:33 +02:00
|
|
|
}
|