2019-09-25 05:28:19 -07:00
|
|
|
// run-rustfix
|
|
|
|
|
2020-04-02 17:36:49 -07:00
|
|
|
#![allow(unused, clippy::needless_bool)]
|
2019-09-25 05:28:19 -07:00
|
|
|
#![allow(clippy::if_same_then_else, clippy::single_match)]
|
2018-07-28 17:34:52 +02:00
|
|
|
#![warn(clippy::needless_return)]
|
2015-08-11 18:55:07 +02:00
|
|
|
|
2019-06-19 14:56:02 +02:00
|
|
|
macro_rules! the_answer {
|
2019-06-20 13:44:00 +02:00
|
|
|
() => {
|
|
|
|
42
|
|
|
|
};
|
2019-06-19 14:56:02 +02:00
|
|
|
}
|
|
|
|
|
2015-08-11 18:55:07 +02:00
|
|
|
fn test_end_of_fn() -> bool {
|
|
|
|
if true {
|
|
|
|
// no error!
|
|
|
|
return true;
|
|
|
|
}
|
2015-12-11 16:28:05 +09:00
|
|
|
return true;
|
2015-08-11 18:55:07 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
fn test_no_semicolon() -> bool {
|
2018-12-09 23:26:16 +01:00
|
|
|
return true;
|
2015-08-11 18:55:07 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
fn test_if_block() -> bool {
|
|
|
|
if true {
|
2016-06-07 18:33:11 +02:00
|
|
|
return true;
|
2015-08-11 18:55:07 +02:00
|
|
|
} else {
|
2016-06-07 18:33:11 +02:00
|
|
|
return false;
|
2015-08-11 18:55:07 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn test_match(x: bool) -> bool {
|
|
|
|
match x {
|
2016-07-14 18:32:09 +02:00
|
|
|
true => return false,
|
2015-08-11 18:55:07 +02:00
|
|
|
false => {
|
2016-06-07 18:33:11 +02:00
|
|
|
return true;
|
2018-12-09 23:26:16 +01:00
|
|
|
},
|
2015-08-11 18:55:07 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn test_closure() {
|
|
|
|
let _ = || {
|
2016-06-07 18:33:11 +02:00
|
|
|
return true;
|
2015-08-11 18:55:07 +02:00
|
|
|
};
|
2017-01-15 13:16:02 +09:00
|
|
|
let _ = || return true;
|
2015-08-11 18:55:07 +02:00
|
|
|
}
|
|
|
|
|
2019-06-19 14:56:02 +02: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 13:44:00 +02:00
|
|
|
fn test_void_match(x: u32) {
|
|
|
|
match x {
|
|
|
|
0 => (),
|
|
|
|
_ => return,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-14 09:25:26 +03:00
|
|
|
fn read_line() -> String {
|
|
|
|
use std::io::BufRead;
|
|
|
|
let stdin = ::std::io::stdin();
|
|
|
|
return stdin.lock().lines().next().unwrap().unwrap();
|
|
|
|
}
|
2020-08-13 19:24:34 +03:00
|
|
|
|
2020-08-14 09:25:26 +03:00
|
|
|
fn borrows_but_not_last(value: bool) -> String {
|
|
|
|
if value {
|
|
|
|
use std::io::BufRead;
|
|
|
|
let stdin = ::std::io::stdin();
|
|
|
|
let _a = stdin.lock().lines().next().unwrap().unwrap();
|
|
|
|
return String::from("test");
|
|
|
|
} else {
|
|
|
|
return String::new();
|
2020-08-13 15:14:08 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-08-11 18:55:07 +02:00
|
|
|
fn main() {
|
|
|
|
let _ = test_end_of_fn();
|
|
|
|
let _ = test_no_semicolon();
|
|
|
|
let _ = test_if_block();
|
|
|
|
let _ = test_match(true);
|
|
|
|
test_closure();
|
|
|
|
}
|