rust/tests/ui/consts/ptr_comparisons.rs

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

44 lines
1.5 KiB
Rust
Raw Normal View History

2020-07-30 05:27:34 -05:00
// compile-flags: --crate-type=lib
2023-08-01 11:22:33 -05:00
// check-pass
2020-07-30 05:27:34 -05:00
#![feature(
core_intrinsics,
const_raw_ptr_comparison,
)]
const FOO: &usize = &42;
macro_rules! check {
(eq, $a:expr, $b:expr) => {
pub const _: () =
assert!(std::intrinsics::ptr_guaranteed_cmp($a as *const u8, $b as *const u8) == 1);
2020-07-30 05:27:34 -05:00
};
(ne, $a:expr, $b:expr) => {
pub const _: () =
assert!(std::intrinsics::ptr_guaranteed_cmp($a as *const u8, $b as *const u8) == 0);
2020-07-30 05:27:34 -05:00
};
(!, $a:expr, $b:expr) => {
2020-07-30 05:27:34 -05:00
pub const _: () =
assert!(std::intrinsics::ptr_guaranteed_cmp($a as *const u8, $b as *const u8) == 2);
2020-07-30 05:27:34 -05:00
};
}
check!(eq, 0, 0);
check!(ne, 0, 1);
check!(ne, FOO as *const _, 0);
check!(ne, unsafe { (FOO as *const usize).offset(1) }, 0);
check!(ne, unsafe { (FOO as *const usize as *const u8).offset(3) }, 0);
2020-07-30 05:27:34 -05:00
// We want pointers to be equal to themselves, but aren't checking this yet because
// there are some open questions (e.g. whether function pointers to the same function
2023-08-01 11:22:33 -05:00
// compare equal: they don't necessarily do at runtime).
check!(!, FOO as *const _, FOO as *const _);
2020-07-30 05:27:34 -05:00
2023-08-01 11:22:33 -05:00
// aside from 0, these pointers might end up pretty much anywhere.
check!(!, FOO as *const _, 1); // this one could be `ne` by taking into account alignment
check!(!, FOO as *const _, 1024);
2020-07-30 05:27:34 -05:00
2023-08-01 11:22:33 -05:00
// When pointers go out-of-bounds, they *might* become null, so these comparions cannot work.
check!(!, unsafe { (FOO as *const usize).wrapping_add(2) }, 0);
check!(!, unsafe { (FOO as *const usize).wrapping_sub(1) }, 0);