2018-06-04 11:32:06 -05:00
|
|
|
#![feature(const_fn)]
|
|
|
|
|
|
|
|
type Field1 = i32;
|
|
|
|
type Field2 = f32;
|
|
|
|
type Field3 = i64;
|
|
|
|
|
2019-08-30 02:35:02 -05:00
|
|
|
#[repr(C)]
|
2018-06-04 11:32:06 -05:00
|
|
|
union DummyUnion {
|
|
|
|
field1: Field1,
|
|
|
|
field2: Field2,
|
|
|
|
field3: Field3,
|
|
|
|
}
|
|
|
|
|
|
|
|
const FLOAT1_AS_I32: i32 = 1065353216;
|
|
|
|
const UNION: DummyUnion = DummyUnion { field1: FLOAT1_AS_I32 };
|
|
|
|
|
|
|
|
const fn read_field1() -> Field1 {
|
|
|
|
const FIELD1: Field1 = unsafe { UNION.field1 };
|
|
|
|
FIELD1
|
|
|
|
}
|
|
|
|
|
|
|
|
const fn read_field2() -> Field2 {
|
|
|
|
const FIELD2: Field2 = unsafe { UNION.field2 };
|
|
|
|
FIELD2
|
|
|
|
}
|
|
|
|
|
|
|
|
const fn read_field3() -> Field3 {
|
2018-11-06 07:17:40 -06:00
|
|
|
const FIELD3: Field3 = unsafe { UNION.field3 };
|
|
|
|
//~^ ERROR it is undefined behavior to use this value
|
2018-06-04 11:32:06 -05:00
|
|
|
FIELD3
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
assert_eq!(read_field1(), FLOAT1_AS_I32);
|
|
|
|
assert_eq!(read_field2(), 1.0);
|
|
|
|
assert_eq!(read_field3(), unsafe { UNION.field3 });
|
|
|
|
}
|