2022-06-04 13:34:07 +02:00
|
|
|
#![warn(clippy::swap_ptr_to_ref)]
|
|
|
|
|
|
|
|
macro_rules! addr_of_mut_to_ref {
|
|
|
|
($e:expr) => {
|
|
|
|
&mut *core::ptr::addr_of_mut!($e)
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let mut x = 0u32;
|
|
|
|
let y: *mut _ = &mut x;
|
|
|
|
|
|
|
|
unsafe {
|
|
|
|
core::mem::swap(addr_of_mut_to_ref!(x), &mut *y);
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: call to `core::mem::swap` with a parameter derived from a raw pointer
|
|
|
|
//~| NOTE: `-D clippy::swap-ptr-to-ref` implied by `-D warnings`
|
2022-06-04 13:34:07 +02:00
|
|
|
core::mem::swap(&mut *y, addr_of_mut_to_ref!(x));
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: call to `core::mem::swap` with a parameter derived from a raw pointer
|
2022-06-04 13:34:07 +02:00
|
|
|
core::mem::swap(addr_of_mut_to_ref!(x), addr_of_mut_to_ref!(x));
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: call to `core::mem::swap` with a parameter derived from a raw pointer
|
2022-06-04 13:34:07 +02:00
|
|
|
}
|
|
|
|
}
|