rust-clippy/tests/ui/diverging_sub_expression.rs

75 lines
2.2 KiB
Rust

#![warn(clippy::diverging_sub_expression)]
#![allow(clippy::match_same_arms, clippy::overly_complex_bool_expr)]
#![allow(clippy::nonminimal_bool)]
#[allow(clippy::empty_loop)]
fn diverge() -> ! {
loop {}
}
struct A;
impl A {
fn foo(&self) -> ! {
diverge()
}
}
#[allow(unused_variables, clippy::unnecessary_operation, clippy::short_circuit_statement)]
fn main() {
let b = true;
b || diverge();
//~^ ERROR: sub-expression diverges
//~| NOTE: `-D clippy::diverging-sub-expression` implied by `-D warnings`
b || A.foo();
//~^ ERROR: sub-expression diverges
}
#[allow(dead_code, unused_variables)]
#[rustfmt::skip]
fn foobar() {
loop {
let x = match 5 {
4 => return,
5 => continue,
6 => true || return,
//~^ ERROR: sub-expression diverges
7 => true || continue,
//~^ ERROR: sub-expression diverges
8 => break,
9 => diverge(),
3 => true || diverge(),
//~^ ERROR: sub-expression diverges
10 => match 42 {
99 => return,
_ => true || panic!("boo"),
//~^ ERROR: sub-expression diverges
},
// lint blocks as well
15 => true || { return; },
//~^ ERROR: sub-expression diverges
16 => false || { return; },
//~^ ERROR: sub-expression diverges
// ... and when it's a single expression
17 => true || { return },
//~^ ERROR: sub-expression diverges
18 => false || { return },
//~^ ERROR: sub-expression diverges
// ... but not when there's both an expression and a statement
19 => true || { _ = 1; return },
20 => false || { _ = 1; return },
// ... or multiple statements
21 => true || { _ = 1; return; },
22 => false || { _ = 1; return; },
23 => true || { return; true },
24 => true || { return; true },
_ => true || break,
//~^ ERROR: sub-expression diverges
};
}
}
#[allow(unused)]
fn ignore_todo() {
let x: u32 = todo!();
println!("{x}");
}