2019-03-26 09:12:14 -05:00
|
|
|
#![allow(dead_code)]
|
|
|
|
#![warn(clippy::transmuting_null)]
|
|
|
|
#![allow(clippy::zero_ptr)]
|
|
|
|
#![allow(clippy::transmute_ptr_to_ref)]
|
|
|
|
#![allow(clippy::eq_op)]
|
|
|
|
|
|
|
|
// Easy to lint because these only span one line.
|
|
|
|
fn one_liners() {
|
|
|
|
unsafe {
|
|
|
|
let _: &u64 = std::mem::transmute(0 as *const u64);
|
2023-08-24 14:32:12 -05:00
|
|
|
//~^ ERROR: transmuting a known null pointer into a reference
|
|
|
|
//~| NOTE: `-D clippy::transmuting-null` implied by `-D warnings`
|
2019-03-26 09:12:14 -05:00
|
|
|
let _: &u64 = std::mem::transmute(std::ptr::null::<u64>());
|
2023-08-24 14:32:12 -05:00
|
|
|
//~^ ERROR: transmuting a known null pointer into a reference
|
2019-03-26 09:12:14 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub const ZPTR: *const usize = 0 as *const _;
|
|
|
|
pub const NOT_ZPTR: *const usize = 1 as *const _;
|
|
|
|
|
|
|
|
fn transmute_const() {
|
|
|
|
unsafe {
|
|
|
|
// Should raise a lint.
|
|
|
|
let _: &u64 = std::mem::transmute(ZPTR);
|
2023-08-24 14:32:12 -05:00
|
|
|
//~^ ERROR: transmuting a known null pointer into a reference
|
2019-03-26 09:12:14 -05:00
|
|
|
// Should NOT raise a lint.
|
|
|
|
let _: &u64 = std::mem::transmute(NOT_ZPTR);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
one_liners();
|
|
|
|
transmute_const();
|
|
|
|
}
|