rust/tests/run-pass/packed_struct.rs

70 lines
1.4 KiB
Rust
Raw Normal View History

// FIXME: We have to disable this, force_allocation fails.
// TODO: I think this can be triggered even without validation.
// compile-flags: -Zmir-emit-validate=0
2017-07-12 23:06:57 -05:00
#![allow(dead_code)]
2017-07-13 16:18:26 -05:00
#![feature(unsize, coerce_unsized)]
2017-01-30 02:44:52 -06:00
#[repr(packed)]
struct S {
a: i32,
b: i64,
}
2017-07-12 23:06:57 -05:00
#[repr(packed)]
struct Test1<'a> {
x: u8,
other: &'a u32,
}
#[repr(packed)]
struct Test2<'a> {
x: u8,
other: &'a Test1<'a>,
}
fn test(t: Test2) {
let x = *t.other.other;
assert_eq!(x, 42);
}
2017-07-13 16:18:26 -05:00
fn test_unsizing() {
#[repr(packed)]
struct UnalignedPtr<'a, T: ?Sized>
where T: 'a,
{
data: &'a T,
}
impl<'a, T, U> std::ops::CoerceUnsized<UnalignedPtr<'a, U>> for UnalignedPtr<'a, T>
where
T: std::marker::Unsize<U> + ?Sized,
U: ?Sized,
{ }
let arr = [1, 2, 3];
let arr_unaligned: UnalignedPtr<[i32; 3]> = UnalignedPtr { data: &arr };
let arr_unaligned: UnalignedPtr<[i32]> = arr_unaligned;
let _unused = &arr_unaligned; // forcing an allocation, which could also yield "unaligned write"-errors
2017-07-13 16:18:26 -05:00
}
2017-01-30 02:44:52 -06:00
fn main() {
let mut x = S {
2017-01-30 02:44:52 -06:00
a: 42,
b: 99,
};
let a = x.a;
let b = x.b;
assert_eq!(a, 42);
assert_eq!(b, 99);
// can't do `assert_eq!(x.a, 42)`, because `assert_eq!` takes a reference
assert_eq!({x.a}, 42);
assert_eq!({x.b}, 99);
x.b = 77;
assert_eq!({x.b}, 77);
2017-07-12 23:06:57 -05:00
test(Test2 { x: 0, other: &Test1 { x: 0, other: &42 }});
2017-07-13 16:18:26 -05:00
test_unsizing();
2017-01-30 02:44:52 -06:00
}