2022-12-29 14:28:34 +01:00
|
|
|
#![allow(dead_code)]
|
|
|
|
#![warn(clippy::transmute_null_to_fn)]
|
|
|
|
#![allow(clippy::zero_ptr)]
|
|
|
|
|
|
|
|
// Easy to lint because these only span one line.
|
|
|
|
fn one_liners() {
|
|
|
|
unsafe {
|
|
|
|
let _: fn() = std::mem::transmute(0 as *const ());
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: transmuting a known null pointer into a function pointer
|
2022-12-29 14:28:34 +01:00
|
|
|
let _: fn() = std::mem::transmute(std::ptr::null::<()>());
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: transmuting a known null pointer into a function pointer
|
2022-12-29 14:28:34 +01: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 _: fn() = std::mem::transmute(ZPTR);
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: transmuting a known null pointer into a function pointer
|
2022-12-29 14:28:34 +01:00
|
|
|
// Should NOT raise a lint.
|
|
|
|
let _: fn() = std::mem::transmute(NOT_ZPTR);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-09-25 11:28:58 +02:00
|
|
|
fn issue_11485() {
|
|
|
|
unsafe {
|
|
|
|
let _: fn() = std::mem::transmute(0 as *const u8 as *const ());
|
|
|
|
//~^ ERROR: transmuting a known null pointer into a function pointer
|
|
|
|
let _: fn() = std::mem::transmute(std::ptr::null::<()>() as *const u8);
|
|
|
|
//~^ ERROR: transmuting a known null pointer into a function pointer
|
|
|
|
let _: fn() = std::mem::transmute(ZPTR as *const u8);
|
|
|
|
//~^ ERROR: transmuting a known null pointer into a function pointer
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-12-29 14:28:34 +01:00
|
|
|
fn main() {
|
|
|
|
one_liners();
|
|
|
|
transmute_const();
|
|
|
|
}
|