rust/tests/ui/implicit_return.rs

140 lines
2.1 KiB
Rust
Raw Normal View History

#![feature(lint_reasons)]
#![warn(clippy::implicit_return)]
#![allow(clippy::needless_return, clippy::needless_bool, unused, clippy::never_loop)]
2018-12-05 01:59:09 +01:00
fn test_end_of_fn() -> bool {
if true {
// no error!
return true;
}
2018-12-05 01:59:09 +01:00
true
}
fn test_if_block() -> bool {
if true { true } else { false }
2018-12-05 01:59:09 +01:00
}
#[rustfmt::skip]
2018-12-05 01:59:09 +01:00
fn test_match(x: bool) -> bool {
match x {
true => false,
false => { true },
2018-12-05 01:59:09 +01:00
}
}
2019-01-20 13:45:22 +01:00
fn test_match_with_unreachable(x: bool) -> bool {
match x {
true => return false,
false => unreachable!(),
}
}
fn test_loop() -> bool {
loop {
break true;
}
}
2018-12-16 15:42:02 +01:00
fn test_loop_with_block() -> bool {
loop {
{
break true;
}
}
}
fn test_loop_with_nests() -> bool {
loop {
if true {
2018-12-16 22:20:05 +01:00
break true;
} else {
2018-12-16 22:20:05 +01:00
let _ = true;
2018-12-16 15:42:02 +01:00
}
}
}
2019-01-20 13:45:22 +01:00
#[allow(clippy::redundant_pattern_matching)]
fn test_loop_with_if_let() -> bool {
loop {
if let Some(x) = Some(true) {
return x;
}
}
}
2018-12-05 01:59:09 +01:00
fn test_closure() {
#[rustfmt::skip]
let _ = || { true };
2018-12-05 01:59:09 +01:00
let _ = || true;
}
fn test_panic() -> bool {
panic!()
}
fn test_return_macro() -> String {
format!("test {}", "test")
}
fn macro_branch_test() -> bool {
macro_rules! m {
($t:expr, $f:expr) => {
if true { $t } else { $f }
};
}
m!(true, false)
2018-12-05 01:59:09 +01:00
}
fn loop_test() -> bool {
'outer: loop {
if true {
break true;
}
let _ = loop {
if false {
break 'outer false;
}
if true {
break true;
}
};
}
}
fn loop_macro_test() -> bool {
macro_rules! m {
($e:expr) => {
break $e
};
}
loop {
m!(true);
}
}
fn divergent_test() -> bool {
fn diverge() -> ! {
panic!()
}
diverge()
}
// issue #6940
async fn foo() -> bool {
true
}
fn main() {}
fn check_expect() -> bool {
if true {
// no error!
return true;
}
#[expect(clippy::implicit_return)]
true
}