blob: b6afe7898906c8a06089e7d6b0fa4a7b229a28fe (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
|
#![warn(clippy::manual_dangling_ptr)]
use std::mem;
pub fn foo(_const: *const f32, _mut: *mut i32) {}
fn main() {
let _: *const u8 = std::ptr::dangling();
//~^ manual_dangling_ptr
let _ = std::ptr::dangling::<u32>();
//~^ manual_dangling_ptr
let _ = std::ptr::dangling_mut::<f32>();
//~^ manual_dangling_ptr
let _ = std::ptr::dangling::<u8>();
//~^ manual_dangling_ptr
let _ = std::ptr::dangling::<u32>();
//~^ manual_dangling_ptr
let _ = std::ptr::dangling::<usize>();
//~^ manual_dangling_ptr
foo(std::ptr::dangling(), std::ptr::dangling_mut());
//~^ manual_dangling_ptr
//~| manual_dangling_ptr
}
fn should_not_lint() {
let _ = 0x10 as *mut i32;
let _ = mem::align_of::<u32>() as *const u8;
foo(0 as _, 0 as _);
}
#[clippy::msrv = "1.83"]
fn _msrv_1_83() {
// `{core, std}::ptr::dangling` was stabilized in 1.84. Do not lint this
foo(4 as *const _, 4 as *mut _);
}
#[clippy::msrv = "1.84"]
fn _msrv_1_84() {
foo(std::ptr::dangling(), std::ptr::dangling_mut());
//~^ manual_dangling_ptr
//~| manual_dangling_ptr
}
|