2022-11-24 09:47:50 +01:00
|
|
|
#![warn(clippy::undocumented_unsafe_blocks, clippy::unnecessary_safety_comment)]
|
2023-06-10 06:43:30 -05:00
|
|
|
#![allow(clippy::let_unit_value, clippy::missing_safety_doc, clippy::needless_if)]
|
2022-11-24 09:47:50 +01:00
|
|
|
|
|
|
|
mod unsafe_items_invalid_comment {
|
|
|
|
// SAFETY:
|
|
|
|
const CONST: u32 = 0;
|
|
|
|
// SAFETY:
|
|
|
|
static STATIC: u32 = 0;
|
|
|
|
// SAFETY:
|
|
|
|
struct Struct;
|
|
|
|
// SAFETY:
|
|
|
|
enum Enum {}
|
|
|
|
// SAFETY:
|
|
|
|
mod module {}
|
|
|
|
}
|
|
|
|
|
|
|
|
mod unnecessary_from_macro {
|
|
|
|
trait T {}
|
|
|
|
|
|
|
|
macro_rules! no_safety_comment {
|
|
|
|
($t:ty) => {
|
|
|
|
impl T for $t {}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
// FIXME: This is not caught
|
|
|
|
// Safety: unnecessary
|
|
|
|
no_safety_comment!(());
|
|
|
|
|
|
|
|
macro_rules! with_safety_comment {
|
|
|
|
($t:ty) => {
|
|
|
|
// Safety: unnecessary
|
|
|
|
impl T for $t {}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
with_safety_comment!(i32);
|
|
|
|
}
|
|
|
|
|
|
|
|
fn unnecessary_on_stmt_and_expr() -> u32 {
|
|
|
|
// SAFETY: unnecessary
|
|
|
|
let num = 42;
|
|
|
|
|
|
|
|
// SAFETY: unnecessary
|
|
|
|
if num > 24 {}
|
|
|
|
|
|
|
|
// SAFETY: unnecessary
|
|
|
|
24
|
|
|
|
}
|
|
|
|
|
2023-01-09 18:49:46 +09:00
|
|
|
mod issue_10084 {
|
|
|
|
unsafe fn bar() -> i32 {
|
|
|
|
42
|
|
|
|
}
|
|
|
|
|
|
|
|
macro_rules! foo {
|
|
|
|
() => {
|
|
|
|
// SAFETY: This is necessary
|
|
|
|
unsafe { bar() }
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
foo!();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-11-24 09:47:50 +01:00
|
|
|
fn main() {}
|