2022-12-29 07:28:34 -06:00
|
|
|
#![feature(yeet_expr)]
|
2021-04-08 10:50:13 -05:00
|
|
|
#![allow(unused)]
|
2021-10-07 04:21:30 -05:00
|
|
|
#![allow(
|
|
|
|
clippy::if_same_then_else,
|
|
|
|
clippy::single_match,
|
|
|
|
clippy::needless_bool,
|
2023-06-02 04:41:57 -05:00
|
|
|
clippy::equatable_if_let,
|
|
|
|
clippy::needless_else
|
2021-10-07 04:21:30 -05:00
|
|
|
)]
|
2018-07-28 10:34:52 -05:00
|
|
|
#![warn(clippy::needless_return)]
|
2015-08-11 11:55:07 -05:00
|
|
|
|
2022-06-30 03:50:09 -05:00
|
|
|
use std::cell::RefCell;
|
|
|
|
|
2019-06-19 07:56:02 -05:00
|
|
|
macro_rules! the_answer {
|
2019-06-20 06:44:00 -05:00
|
|
|
() => {
|
|
|
|
42
|
|
|
|
};
|
2019-06-19 07:56:02 -05:00
|
|
|
}
|
|
|
|
|
2015-08-11 11:55:07 -05:00
|
|
|
fn test_end_of_fn() -> bool {
|
|
|
|
if true {
|
|
|
|
// no error!
|
|
|
|
return true;
|
|
|
|
}
|
2015-12-11 01:28:05 -06:00
|
|
|
return true;
|
2015-08-11 11:55:07 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
fn test_no_semicolon() -> bool {
|
2018-12-09 16:26:16 -06:00
|
|
|
return true;
|
2015-08-11 11:55:07 -05:00
|
|
|
}
|
|
|
|
|
2023-01-27 14:09:08 -06:00
|
|
|
#[rustfmt::skip]
|
|
|
|
fn test_multiple_semicolon() -> bool {
|
|
|
|
return true;;;
|
|
|
|
}
|
|
|
|
|
|
|
|
#[rustfmt::skip]
|
|
|
|
fn test_multiple_semicolon_with_spaces() -> bool {
|
|
|
|
return true;; ; ;
|
|
|
|
}
|
|
|
|
|
2015-08-11 11:55:07 -05:00
|
|
|
fn test_if_block() -> bool {
|
|
|
|
if true {
|
2016-06-07 11:33:11 -05:00
|
|
|
return true;
|
2015-08-11 11:55:07 -05:00
|
|
|
} else {
|
2016-06-07 11:33:11 -05:00
|
|
|
return false;
|
2015-08-11 11:55:07 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn test_match(x: bool) -> bool {
|
|
|
|
match x {
|
2016-07-14 11:32:09 -05:00
|
|
|
true => return false,
|
2015-08-11 11:55:07 -05:00
|
|
|
false => {
|
2016-06-07 11:33:11 -05:00
|
|
|
return true;
|
2018-12-09 16:26:16 -06:00
|
|
|
},
|
2015-08-11 11:55:07 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn test_closure() {
|
|
|
|
let _ = || {
|
2016-06-07 11:33:11 -05:00
|
|
|
return true;
|
2015-08-11 11:55:07 -05:00
|
|
|
};
|
2017-01-14 22:16:02 -06:00
|
|
|
let _ = || return true;
|
2015-08-11 11:55:07 -05:00
|
|
|
}
|
|
|
|
|
2019-06-19 07:56:02 -05:00
|
|
|
fn test_macro_call() -> i32 {
|
|
|
|
return the_answer!();
|
|
|
|
}
|
|
|
|
|
|
|
|
fn test_void_fun() {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
fn test_void_if_fun(b: bool) {
|
|
|
|
if b {
|
|
|
|
return;
|
|
|
|
} else {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-06-20 06:44:00 -05:00
|
|
|
fn test_void_match(x: u32) {
|
|
|
|
match x {
|
|
|
|
0 => (),
|
|
|
|
_ => return,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-12-30 08:10:43 -06:00
|
|
|
fn test_nested_match(x: u32) {
|
|
|
|
match x {
|
|
|
|
0 => (),
|
|
|
|
1 => {
|
|
|
|
let _ = 42;
|
|
|
|
return;
|
|
|
|
},
|
|
|
|
_ => return,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-06-30 03:50:09 -05:00
|
|
|
fn temporary_outlives_local() -> String {
|
|
|
|
let x = RefCell::<String>::default();
|
|
|
|
return x.borrow().clone();
|
2020-08-28 09:10:16 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
fn borrows_but_not_last(value: bool) -> String {
|
|
|
|
if value {
|
2022-06-30 03:50:09 -05:00
|
|
|
let x = RefCell::<String>::default();
|
|
|
|
let _a = x.borrow().clone();
|
2020-08-28 09:10:16 -05:00
|
|
|
return String::from("test");
|
|
|
|
} else {
|
|
|
|
return String::new();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-01-15 03:56:44 -06:00
|
|
|
macro_rules! needed_return {
|
|
|
|
($e:expr) => {
|
|
|
|
if $e > 3 {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
fn test_return_in_macro() {
|
|
|
|
// This will return and the macro below won't be executed. Removing the `return` from the macro
|
|
|
|
// will change semantics.
|
|
|
|
needed_return!(10);
|
|
|
|
needed_return!(0);
|
|
|
|
}
|
|
|
|
|
2021-01-30 11:06:34 -06:00
|
|
|
mod issue6501 {
|
2021-12-06 05:33:31 -06:00
|
|
|
#[allow(clippy::unnecessary_lazy_evaluations)]
|
2021-01-30 11:06:34 -06:00
|
|
|
fn foo(bar: Result<(), ()>) {
|
|
|
|
bar.unwrap_or_else(|_| return)
|
|
|
|
}
|
|
|
|
|
|
|
|
fn test_closure() {
|
|
|
|
let _ = || {
|
|
|
|
return;
|
|
|
|
};
|
|
|
|
let _ = || return;
|
|
|
|
}
|
|
|
|
|
|
|
|
struct Foo;
|
|
|
|
#[allow(clippy::unnecessary_lazy_evaluations)]
|
|
|
|
fn bar(res: Result<Foo, u8>) -> Foo {
|
|
|
|
res.unwrap_or_else(|_| return Foo)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-04-22 04:31:13 -05:00
|
|
|
async fn async_test_end_of_fn() -> bool {
|
|
|
|
if true {
|
|
|
|
// no error!
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
async fn async_test_no_semicolon() -> bool {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
async fn async_test_if_block() -> bool {
|
|
|
|
if true {
|
|
|
|
return true;
|
|
|
|
} else {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
async fn async_test_match(x: bool) -> bool {
|
|
|
|
match x {
|
|
|
|
true => return false,
|
|
|
|
false => {
|
|
|
|
return true;
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
async fn async_test_closure() {
|
|
|
|
let _ = || {
|
|
|
|
return true;
|
|
|
|
};
|
|
|
|
let _ = || return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
async fn async_test_macro_call() -> i32 {
|
|
|
|
return the_answer!();
|
|
|
|
}
|
|
|
|
|
|
|
|
async fn async_test_void_fun() {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
async fn async_test_void_if_fun(b: bool) {
|
|
|
|
if b {
|
|
|
|
return;
|
|
|
|
} else {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
async fn async_test_void_match(x: u32) {
|
|
|
|
match x {
|
|
|
|
0 => (),
|
|
|
|
_ => return,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-06-30 03:50:09 -05:00
|
|
|
async fn async_temporary_outlives_local() -> String {
|
|
|
|
let x = RefCell::<String>::default();
|
|
|
|
return x.borrow().clone();
|
2015-08-11 11:55:07 -05:00
|
|
|
}
|
2021-04-22 04:31:13 -05:00
|
|
|
|
|
|
|
async fn async_borrows_but_not_last(value: bool) -> String {
|
|
|
|
if value {
|
2022-06-30 03:50:09 -05:00
|
|
|
let x = RefCell::<String>::default();
|
|
|
|
let _a = x.borrow().clone();
|
2021-04-22 04:31:13 -05:00
|
|
|
return String::from("test");
|
|
|
|
} else {
|
|
|
|
return String::new();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
async fn async_test_return_in_macro() {
|
|
|
|
needed_return!(10);
|
|
|
|
needed_return!(0);
|
|
|
|
}
|
|
|
|
|
2021-09-28 12:03:12 -05:00
|
|
|
fn let_else() {
|
|
|
|
let Some(1) = Some(1) else { return };
|
|
|
|
}
|
|
|
|
|
2022-06-04 06:34:07 -05:00
|
|
|
fn needless_return_macro() -> String {
|
|
|
|
let _ = "foo";
|
|
|
|
let _ = "bar";
|
|
|
|
return format!("Hello {}", "world!");
|
|
|
|
}
|
|
|
|
|
2024-07-01 06:49:16 -05:00
|
|
|
fn issue_9361(n: i32) -> i32 {
|
|
|
|
#[expect(clippy::arithmetic_side_effects)]
|
2023-05-20 08:39:26 -05:00
|
|
|
return n + n;
|
2022-06-30 03:50:09 -05:00
|
|
|
}
|
|
|
|
|
2024-07-01 06:49:16 -05:00
|
|
|
mod issue_12998 {
|
|
|
|
fn expect_lint() -> i32 {
|
|
|
|
let x = 1;
|
|
|
|
|
|
|
|
#[expect(clippy::needless_return)]
|
|
|
|
return x;
|
|
|
|
}
|
|
|
|
|
|
|
|
fn expect_group() -> i32 {
|
|
|
|
let x = 1;
|
|
|
|
|
|
|
|
#[expect(clippy::style)]
|
|
|
|
return x;
|
|
|
|
}
|
|
|
|
|
|
|
|
fn expect_all() -> i32 {
|
|
|
|
let x = 1;
|
|
|
|
|
|
|
|
#[expect(clippy::all)]
|
|
|
|
return x;
|
|
|
|
}
|
|
|
|
|
|
|
|
fn expect_warnings() -> i32 {
|
|
|
|
let x = 1;
|
|
|
|
|
|
|
|
#[expect(warnings)]
|
|
|
|
return x;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-10-06 02:44:38 -05:00
|
|
|
fn issue8336(x: i32) -> bool {
|
|
|
|
if x > 0 {
|
|
|
|
println!("something");
|
|
|
|
return true;
|
|
|
|
} else {
|
|
|
|
return false;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
fn issue8156(x: u8) -> u64 {
|
|
|
|
match x {
|
|
|
|
80 => {
|
|
|
|
return 10;
|
|
|
|
},
|
|
|
|
_ => {
|
|
|
|
return 100;
|
|
|
|
},
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
// Ideally the compiler should throw `unused_braces` in this case
|
|
|
|
fn issue9192() -> i32 {
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
fn issue9503(x: usize) -> isize {
|
|
|
|
unsafe {
|
|
|
|
if x > 12 {
|
|
|
|
return *(x as *const isize);
|
|
|
|
} else {
|
|
|
|
return !*(x as *const isize);
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2022-12-01 11:29:38 -06:00
|
|
|
mod issue9416 {
|
|
|
|
pub fn with_newline() {
|
|
|
|
let _ = 42;
|
|
|
|
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
#[rustfmt::skip]
|
|
|
|
pub fn oneline() {
|
|
|
|
let _ = 42; return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-12-29 07:28:34 -06:00
|
|
|
fn issue9947() -> Result<(), String> {
|
|
|
|
do yeet "hello";
|
|
|
|
}
|
|
|
|
|
2023-01-12 12:48:13 -06:00
|
|
|
// without anyhow, but triggers the same bug I believe
|
|
|
|
#[expect(clippy::useless_format)]
|
|
|
|
fn issue10051() -> Result<String, String> {
|
|
|
|
if true {
|
|
|
|
return Ok(format!("ok!"));
|
|
|
|
} else {
|
|
|
|
return Err(format!("err!"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-02-25 18:08:29 -06:00
|
|
|
mod issue10049 {
|
|
|
|
fn single() -> u32 {
|
|
|
|
return if true { 1 } else { 2 };
|
|
|
|
}
|
|
|
|
|
|
|
|
fn multiple(b1: bool, b2: bool, b3: bool) -> u32 {
|
|
|
|
return if b1 { 0 } else { 1 } | if b2 { 2 } else { 3 } | if b3 { 4 } else { 5 };
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-04-11 08:31:08 -05:00
|
|
|
fn test_match_as_stmt() {
|
|
|
|
let x = 9;
|
|
|
|
match x {
|
|
|
|
1 => 2,
|
|
|
|
2 => return,
|
|
|
|
_ => 0,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2024-03-21 16:20:40 -05:00
|
|
|
fn allow_works() -> i32 {
|
|
|
|
#[allow(clippy::needless_return, clippy::match_single_binding)]
|
|
|
|
match () {
|
|
|
|
() => return 42,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-05-30 03:49:05 -05:00
|
|
|
fn conjunctive_blocks() -> String {
|
|
|
|
return { "a".to_string() } + "b" + { "c" };
|
|
|
|
}
|
|
|
|
|
2021-04-22 04:31:13 -05:00
|
|
|
fn main() {}
|