2023-12-28 20:15:45 -06:00
|
|
|
//@aux-build:proc_macro_attr.rs
|
|
|
|
|
2023-11-30 01:41:54 -06:00
|
|
|
#![warn(clippy::blocks_in_conditions)]
|
2023-06-10 06:43:30 -05:00
|
|
|
#![allow(unused, clippy::let_and_return, clippy::needless_if)]
|
2018-07-28 10:34:52 -05:00
|
|
|
#![warn(clippy::nonminimal_bool)]
|
2015-11-19 23:22:52 -06:00
|
|
|
|
2016-01-02 10:11:48 -06:00
|
|
|
macro_rules! blocky {
|
2021-03-01 11:53:33 -06:00
|
|
|
() => {{ true }};
|
2016-01-02 10:11:48 -06:00
|
|
|
}
|
|
|
|
|
2016-01-31 16:25:10 -06:00
|
|
|
macro_rules! blocky_too {
|
|
|
|
() => {{
|
|
|
|
let r = true;
|
|
|
|
r
|
2018-12-09 16:26:16 -06:00
|
|
|
}};
|
2016-01-31 16:25:10 -06:00
|
|
|
}
|
|
|
|
|
2016-01-02 10:11:48 -06:00
|
|
|
fn macro_if() {
|
2018-12-09 16:26:16 -06:00
|
|
|
if blocky!() {}
|
2016-12-21 05:30:41 -06:00
|
|
|
|
2018-12-09 16:26:16 -06:00
|
|
|
if blocky_too!() {}
|
2016-01-02 10:11:48 -06:00
|
|
|
}
|
2016-01-31 16:25:10 -06:00
|
|
|
|
2015-11-19 23:22:52 -06:00
|
|
|
fn condition_has_block() -> i32 {
|
2017-02-08 07:58:07 -06:00
|
|
|
if {
|
2023-11-30 01:41:54 -06:00
|
|
|
//~^ ERROR: in an `if` condition, avoid complex blocks or closures with blocks; instead, move the block or closure higher and bind it with a `let`
|
2015-11-19 23:22:52 -06:00
|
|
|
let x = 3;
|
|
|
|
x == 3
|
|
|
|
} {
|
|
|
|
6
|
|
|
|
} else {
|
|
|
|
10
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn condition_has_block_with_single_expression() -> i32 {
|
2021-03-01 11:53:33 -06:00
|
|
|
if { true } { 6 } else { 10 }
|
2023-11-30 01:41:54 -06:00
|
|
|
//~^ ERROR: omit braces around single expression condition
|
2015-11-19 23:22:52 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
fn condition_is_normal() -> i32 {
|
|
|
|
let x = 3;
|
2021-03-01 11:53:33 -06:00
|
|
|
if true && x == 3 { 6 } else { 10 }
|
2015-11-19 23:22:52 -06:00
|
|
|
}
|
|
|
|
|
2015-12-22 19:12:08 -06:00
|
|
|
fn condition_is_unsafe_block() {
|
|
|
|
let a: i32 = 1;
|
|
|
|
|
|
|
|
// this should not warn because the condition is an unsafe block
|
|
|
|
if unsafe { 1u32 == std::mem::transmute(a) } {
|
|
|
|
println!("1u32 == a");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-08-27 02:43:19 -05:00
|
|
|
fn block_in_assert() {
|
|
|
|
let opt = Some(42);
|
2021-03-01 11:53:33 -06:00
|
|
|
assert!(
|
|
|
|
opt.as_ref()
|
|
|
|
.map(|val| {
|
|
|
|
let mut v = val * 2;
|
|
|
|
v -= 1;
|
|
|
|
v * 3
|
|
|
|
})
|
|
|
|
.is_some()
|
|
|
|
);
|
2019-08-27 02:43:19 -05:00
|
|
|
}
|
2020-02-04 09:08:39 -06:00
|
|
|
|
2023-11-21 19:29:44 -06:00
|
|
|
// issue #11814
|
|
|
|
fn block_in_match_expr(num: i32) -> i32 {
|
|
|
|
match {
|
2023-11-30 01:41:54 -06:00
|
|
|
//~^ ERROR: in a `match` scrutinee, avoid complex blocks or closures with blocks; instead, move the block or closure higher and bind it with a `let`
|
2023-11-21 19:29:44 -06:00
|
|
|
let opt = Some(2);
|
|
|
|
opt
|
|
|
|
} {
|
|
|
|
Some(0) => 1,
|
|
|
|
Some(n) => num * 2,
|
|
|
|
None => 0,
|
2023-11-30 01:41:54 -06:00
|
|
|
};
|
|
|
|
|
|
|
|
match unsafe {
|
|
|
|
let hearty_hearty_hearty = vec![240, 159, 146, 150];
|
|
|
|
String::from_utf8_unchecked(hearty_hearty_hearty).as_str()
|
|
|
|
} {
|
|
|
|
"💖" => 1,
|
|
|
|
"what" => 2,
|
|
|
|
_ => 3,
|
2023-11-21 19:29:44 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-01-18 18:06:08 -06:00
|
|
|
// issue #12162
|
|
|
|
macro_rules! timed {
|
|
|
|
($name:expr, $body:expr $(,)?) => {{
|
|
|
|
let __scope = ();
|
|
|
|
$body
|
|
|
|
}};
|
|
|
|
}
|
|
|
|
|
|
|
|
fn issue_12162() {
|
|
|
|
if timed!("check this!", false) {
|
|
|
|
println!();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-12-28 20:15:45 -06:00
|
|
|
mod issue_12016 {
|
|
|
|
#[proc_macro_attr::fake_desugar_await]
|
|
|
|
pub async fn await_becomes_block() -> i32 {
|
|
|
|
match Some(1).await {
|
|
|
|
Some(1) => 2,
|
|
|
|
Some(2) => 3,
|
|
|
|
_ => 0,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-02-04 09:08:39 -06:00
|
|
|
fn main() {}
|