2020-07-02 14:32:12 +09:00
|
|
|
// run-rustfix
|
|
|
|
|
2014-10-27 15:37:07 -07:00
|
|
|
#![deny(unused_parens)]
|
2020-07-02 14:32:12 +09:00
|
|
|
#![allow(while_true)] // for rustfix
|
2014-01-19 14:57:47 +11:00
|
|
|
|
2014-12-31 17:32:49 +13:00
|
|
|
#[derive(Eq, PartialEq)]
|
2014-06-25 09:00:46 +10:00
|
|
|
struct X { y: bool }
|
|
|
|
impl X {
|
2017-12-23 19:28:33 -08:00
|
|
|
fn foo(&self, conjunct: bool) -> bool { self.y && conjunct }
|
2014-06-25 09:00:46 +10:00
|
|
|
}
|
|
|
|
|
2015-01-08 21:54:35 +11:00
|
|
|
fn foo() -> isize {
|
2015-01-31 17:23:42 +01:00
|
|
|
return (1); //~ ERROR unnecessary parentheses around `return` value
|
2014-01-19 14:57:47 +11:00
|
|
|
}
|
2017-12-23 19:28:33 -08:00
|
|
|
fn bar(y: bool) -> X {
|
|
|
|
return (X { y }); //~ ERROR unnecessary parentheses around `return` value
|
2014-06-25 09:00:46 +10:00
|
|
|
}
|
2014-01-19 14:57:47 +11:00
|
|
|
|
2020-07-02 14:32:12 +09:00
|
|
|
pub fn unused_parens_around_return_type() -> (u32) { //~ ERROR unnecessary parentheses around type
|
2019-10-04 01:56:57 -04:00
|
|
|
panic!()
|
|
|
|
}
|
|
|
|
|
2020-07-02 14:32:12 +09:00
|
|
|
pub fn unused_parens_around_block_return() -> u32 {
|
|
|
|
let _foo = {
|
2020-01-23 00:42:35 -05:00
|
|
|
(5) //~ ERROR unnecessary parentheses around block return value
|
|
|
|
};
|
|
|
|
(5) //~ ERROR unnecessary parentheses around block return value
|
|
|
|
}
|
|
|
|
|
2020-07-02 14:32:12 +09:00
|
|
|
pub trait Trait {
|
2019-10-04 01:56:57 -04:00
|
|
|
fn test(&self);
|
|
|
|
}
|
|
|
|
|
2020-07-02 14:32:12 +09:00
|
|
|
pub fn passes_unused_parens_lint() -> &'static (dyn Trait) {
|
2019-10-04 01:56:57 -04:00
|
|
|
panic!()
|
|
|
|
}
|
|
|
|
|
2019-12-03 12:35:09 +01:00
|
|
|
macro_rules! baz {
|
|
|
|
($($foo:expr),+) => {
|
|
|
|
($($foo),*)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-07-02 14:32:12 +09:00
|
|
|
pub const CONST_ITEM: usize = (10); //~ ERROR unnecessary parentheses around assigned value
|
|
|
|
pub static STATIC_ITEM: usize = (10); //~ ERROR unnecessary parentheses around assigned value
|
2020-02-01 18:30:52 -05:00
|
|
|
|
2014-01-19 14:57:47 +11:00
|
|
|
fn main() {
|
|
|
|
foo();
|
2017-12-23 19:28:33 -08:00
|
|
|
bar((true)); //~ ERROR unnecessary parentheses around function argument
|
2014-01-19 14:57:47 +11:00
|
|
|
|
|
|
|
if (true) {} //~ ERROR unnecessary parentheses around `if` condition
|
|
|
|
while (true) {} //~ ERROR unnecessary parentheses around `while` condition
|
2020-03-31 18:42:54 +02:00
|
|
|
match (true) { //~ ERROR unnecessary parentheses around `match` scrutinee expression
|
2014-01-19 14:57:47 +11:00
|
|
|
_ => {}
|
|
|
|
}
|
2020-03-31 18:42:54 +02:00
|
|
|
if let 1 = (1) {} //~ ERROR unnecessary parentheses around `let` scrutinee expression
|
|
|
|
while let 1 = (2) {} //~ ERROR unnecessary parentheses around `let` scrutinee expression
|
2014-06-25 09:00:46 +10:00
|
|
|
let v = X { y: false };
|
|
|
|
// struct lits needs parens, so these shouldn't warn.
|
|
|
|
if (v == X { y: true }) {}
|
|
|
|
if (X { y: true } == v) {}
|
|
|
|
if (X { y: false }.y) {}
|
2020-10-14 01:13:48 +02:00
|
|
|
// this shouldn't warn, because the parens are necessary to disambiguate let chains
|
|
|
|
if let true = (true && false) {}
|
2014-06-25 09:00:46 +10:00
|
|
|
|
2017-12-23 19:28:33 -08:00
|
|
|
while (X { y: false }.foo(true)) {}
|
2014-06-25 09:00:46 +10:00
|
|
|
while (true | X { y: false }.y) {}
|
|
|
|
|
|
|
|
match (X { y: false }) {
|
|
|
|
_ => {}
|
|
|
|
}
|
|
|
|
|
2017-12-23 19:28:33 -08:00
|
|
|
X { y: false }.foo((true)); //~ ERROR unnecessary parentheses around method argument
|
|
|
|
|
2015-01-31 17:23:42 +01:00
|
|
|
let mut _a = (0); //~ ERROR unnecessary parentheses around assigned value
|
|
|
|
_a = (0); //~ ERROR unnecessary parentheses around assigned value
|
|
|
|
_a += (1); //~ ERROR unnecessary parentheses around assigned value
|
2019-12-03 12:35:09 +01:00
|
|
|
|
|
|
|
let _a = baz!(3, 4);
|
|
|
|
let _b = baz!(3);
|
2014-01-19 14:57:47 +11:00
|
|
|
}
|