2018-08-30 07:18:55 -05:00
|
|
|
// run-pass
|
2016-09-08 12:18:07 -05:00
|
|
|
// Issue 36278: On an unsized struct with >1 level of nontrivial
|
|
|
|
// nesting, ensure we are computing dynamic size of prefix correctly.
|
|
|
|
|
|
|
|
use std::mem;
|
|
|
|
|
|
|
|
const SZ: usize = 100;
|
2022-07-25 15:36:03 -05:00
|
|
|
#[allow(unused_tuple_struct_fields)]
|
2016-09-08 12:18:07 -05:00
|
|
|
struct P<T: ?Sized>([u8; SZ], T);
|
|
|
|
|
|
|
|
type Ack<T> = P<P<T>>;
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let size_of_sized; let size_of_unsized;
|
|
|
|
let x: Box<Ack<[u8; 0]>> = Box::new(P([0; SZ], P([0; SZ], [0; 0])));
|
|
|
|
size_of_sized = mem::size_of_val::<Ack<_>>(&x);
|
|
|
|
let y: Box<Ack<[u8 ]>> = x;
|
|
|
|
size_of_unsized = mem::size_of_val::<Ack<_>>(&y);
|
|
|
|
assert_eq!(size_of_sized, size_of_unsized);
|
|
|
|
}
|