2021-03-31 08:09:16 +00:00
|
|
|
// stderr-per-bitwidth
|
2022-03-27 00:06:26 -07:00
|
|
|
// ignore-debug (the debug assertions change the error)
|
2022-12-22 16:40:50 +01:00
|
|
|
// Strip out raw byte dumps to make comparison platform-independent:
|
|
|
|
// normalize-stderr-test "(the raw bytes of the constant) \(size: [0-9]*, align: [0-9]*\)" -> "$1 (size: $$SIZE, align: $$ALIGN)"
|
|
|
|
// normalize-stderr-test "([0-9a-f][0-9a-f] |╾─*a(lloc)?[0-9]+(\+[a-z0-9]+)?─*╼ )+ *│.*" -> "HEX_DUMP"
|
2019-04-30 12:56:38 +02:00
|
|
|
use std::alloc::Layout;
|
|
|
|
|
|
|
|
// ok
|
|
|
|
const LAYOUT_VALID: Layout = unsafe { Layout::from_size_align_unchecked(0x1000, 0x08) };
|
|
|
|
|
|
|
|
// not ok, since alignment needs to be non-zero.
|
2022-03-27 00:06:26 -07:00
|
|
|
const LAYOUT_INVALID_ZERO: Layout = unsafe { Layout::from_size_align_unchecked(0x1000, 0x00) };
|
|
|
|
//~^ ERROR it is undefined behavior to use this value
|
|
|
|
|
|
|
|
// not ok, since alignment needs to be a power of two.
|
|
|
|
const LAYOUT_INVALID_THREE: Layout = unsafe { Layout::from_size_align_unchecked(9, 3) };
|
2019-04-30 12:56:38 +02:00
|
|
|
//~^ ERROR it is undefined behavior to use this value
|
|
|
|
|
|
|
|
fn main() {}
|