2020-12-20 17:19:49 +01:00
|
|
|
#![warn(clippy::redundant_else)]
|
2021-12-06 12:33:31 +01:00
|
|
|
#![allow(clippy::needless_return, clippy::if_same_then_else, clippy::needless_late_init)]
|
2020-12-20 17:19:49 +01:00
|
|
|
|
|
|
|
fn main() {
|
|
|
|
loop {
|
|
|
|
// break
|
|
|
|
if foo() {
|
|
|
|
println!("Love your neighbor;");
|
|
|
|
break;
|
|
|
|
} else {
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: redundant else block
|
2020-12-20 17:19:49 +01:00
|
|
|
println!("yet don't pull down your hedge.");
|
|
|
|
}
|
|
|
|
// continue
|
|
|
|
if foo() {
|
|
|
|
println!("He that lies down with Dogs,");
|
|
|
|
continue;
|
|
|
|
} else {
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: redundant else block
|
2020-12-20 17:19:49 +01:00
|
|
|
println!("shall rise up with fleas.");
|
|
|
|
}
|
|
|
|
// match block
|
|
|
|
if foo() {
|
|
|
|
match foo() {
|
|
|
|
1 => break,
|
|
|
|
_ => return,
|
|
|
|
}
|
|
|
|
} else {
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: redundant else block
|
2020-12-20 17:19:49 +01:00
|
|
|
println!("You may delay, but time will not.");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// else if
|
|
|
|
if foo() {
|
|
|
|
return;
|
|
|
|
} else if foo() {
|
|
|
|
return;
|
|
|
|
} else {
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: redundant else block
|
2020-12-20 17:19:49 +01:00
|
|
|
println!("A fat kitchen makes a lean will.");
|
|
|
|
}
|
|
|
|
// let binding outside of block
|
|
|
|
let _ = {
|
|
|
|
if foo() {
|
|
|
|
return;
|
|
|
|
} else {
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: redundant else block
|
2020-12-20 17:19:49 +01:00
|
|
|
1
|
|
|
|
}
|
|
|
|
};
|
|
|
|
// else if with let binding outside of block
|
|
|
|
let _ = {
|
|
|
|
if foo() {
|
|
|
|
return;
|
|
|
|
} else if foo() {
|
|
|
|
return;
|
|
|
|
} else {
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: redundant else block
|
2020-12-20 17:19:49 +01:00
|
|
|
2
|
|
|
|
}
|
|
|
|
};
|
|
|
|
// inside if let
|
|
|
|
let _ = if let Some(1) = foo() {
|
|
|
|
let _ = 1;
|
|
|
|
if foo() {
|
|
|
|
return;
|
|
|
|
} else {
|
2023-08-24 21:32:12 +02:00
|
|
|
//~^ ERROR: redundant else block
|
2020-12-20 17:19:49 +01:00
|
|
|
1
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
1
|
|
|
|
};
|
|
|
|
|
|
|
|
//
|
|
|
|
// non-lint cases
|
|
|
|
//
|
|
|
|
|
|
|
|
// sanity check
|
|
|
|
if foo() {
|
|
|
|
let _ = 1;
|
|
|
|
} else {
|
|
|
|
println!("Who is wise? He that learns from every one.");
|
|
|
|
}
|
|
|
|
// else if without else
|
|
|
|
if foo() {
|
|
|
|
return;
|
|
|
|
} else if foo() {
|
|
|
|
foo()
|
|
|
|
};
|
|
|
|
// nested if return
|
|
|
|
if foo() {
|
|
|
|
if foo() {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
foo()
|
|
|
|
};
|
|
|
|
// match with non-breaking branch
|
|
|
|
if foo() {
|
|
|
|
match foo() {
|
|
|
|
1 => foo(),
|
|
|
|
_ => return,
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
println!("Three may keep a secret, if two of them are dead.");
|
|
|
|
}
|
|
|
|
// let binding
|
|
|
|
let _ = if foo() {
|
|
|
|
return;
|
|
|
|
} else {
|
|
|
|
1
|
|
|
|
};
|
|
|
|
// assign
|
2021-07-20 23:23:22 -04:00
|
|
|
let mut a;
|
2020-12-20 17:19:49 +01:00
|
|
|
a = if foo() {
|
|
|
|
return;
|
|
|
|
} else {
|
|
|
|
1
|
|
|
|
};
|
|
|
|
// assign-op
|
|
|
|
a += if foo() {
|
|
|
|
return;
|
|
|
|
} else {
|
|
|
|
1
|
|
|
|
};
|
|
|
|
// if return else if else
|
|
|
|
if foo() {
|
|
|
|
return;
|
|
|
|
} else if foo() {
|
|
|
|
1
|
|
|
|
} else {
|
|
|
|
2
|
|
|
|
};
|
|
|
|
// if else if return else
|
|
|
|
if foo() {
|
|
|
|
1
|
|
|
|
} else if foo() {
|
|
|
|
return;
|
|
|
|
} else {
|
|
|
|
2
|
|
|
|
};
|
|
|
|
// else if with let binding
|
|
|
|
let _ = if foo() {
|
|
|
|
return;
|
|
|
|
} else if foo() {
|
|
|
|
return;
|
|
|
|
} else {
|
|
|
|
2
|
|
|
|
};
|
|
|
|
// inside function call
|
|
|
|
Box::new(if foo() {
|
|
|
|
return;
|
|
|
|
} else {
|
|
|
|
1
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
fn foo<T>() -> T {
|
|
|
|
unimplemented!("I'm not Santa Claus")
|
|
|
|
}
|