2016-02-27 10:57:36 -06:00
|
|
|
#![feature(plugin)]
|
|
|
|
#![plugin(clippy)]
|
|
|
|
|
|
|
|
#![deny(clippy)]
|
|
|
|
#![allow(unused_variables)]
|
|
|
|
#![allow(unused_assignments)]
|
|
|
|
#![allow(if_same_then_else)]
|
2016-11-25 08:54:07 -06:00
|
|
|
#![allow(deref_addrof)]
|
2016-02-27 10:57:36 -06:00
|
|
|
|
2016-02-27 10:59:04 -06:00
|
|
|
fn foo() -> bool { true }
|
|
|
|
|
2016-02-27 10:57:36 -06:00
|
|
|
fn main() {
|
2016-02-27 10:59:04 -06:00
|
|
|
// weird `else if` formatting:
|
|
|
|
if foo() {
|
2016-06-05 11:07:12 -05:00
|
|
|
} if foo() {
|
|
|
|
//~^ ERROR this looks like an `else if` but the `else` is missing
|
|
|
|
//~| NOTE add the missing `else` or
|
2016-02-27 10:59:04 -06:00
|
|
|
}
|
|
|
|
|
2016-06-28 08:54:23 -05:00
|
|
|
let _ = { // if as the last expression
|
|
|
|
let _ = 0;
|
|
|
|
|
2016-02-27 10:59:04 -06:00
|
|
|
if foo() {
|
2016-06-05 11:07:12 -05:00
|
|
|
} if foo() {
|
|
|
|
//~^ ERROR this looks like an `else if` but the `else` is missing
|
|
|
|
//~| NOTE add the missing `else` or
|
2016-02-27 10:59:04 -06:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2016-06-28 08:54:23 -05:00
|
|
|
let _ = { // if in the middle of a block
|
|
|
|
if foo() {
|
|
|
|
} if foo() {
|
|
|
|
//~^ ERROR this looks like an `else if` but the `else` is missing
|
|
|
|
//~| NOTE add the missing `else` or
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
}
|
|
|
|
|
|
|
|
let _ = 0;
|
|
|
|
};
|
|
|
|
|
2016-02-27 10:59:04 -06:00
|
|
|
if foo() {
|
2016-06-05 11:07:12 -05:00
|
|
|
} else
|
|
|
|
//~^ ERROR this is an `else if` but the formatting might hide it
|
|
|
|
//~| NOTE remove the `else` or
|
2016-02-27 10:59:04 -06:00
|
|
|
if foo() { // the span of the above error should continue here
|
|
|
|
}
|
|
|
|
|
|
|
|
if foo() {
|
2016-06-05 11:07:12 -05:00
|
|
|
}
|
|
|
|
//~^ ERROR this is an `else if` but the formatting might hide it
|
|
|
|
//~| NOTE remove the `else` or
|
2016-02-27 10:59:04 -06:00
|
|
|
else
|
|
|
|
if foo() { // the span of the above error should continue here
|
|
|
|
}
|
|
|
|
|
|
|
|
// those are ok:
|
|
|
|
if foo() {
|
|
|
|
}
|
|
|
|
if foo() {
|
|
|
|
}
|
|
|
|
|
|
|
|
if foo() {
|
|
|
|
} else if foo() {
|
|
|
|
}
|
|
|
|
|
|
|
|
if foo() {
|
|
|
|
}
|
|
|
|
else if foo() {
|
|
|
|
}
|
|
|
|
|
|
|
|
if foo() {
|
|
|
|
}
|
|
|
|
|
|
|
|
else if
|
|
|
|
|
|
|
|
foo() {}
|
|
|
|
|
2016-02-27 10:57:36 -06:00
|
|
|
// weird op_eq formatting:
|
|
|
|
let mut a = 42;
|
|
|
|
a =- 35;
|
|
|
|
//~^ ERROR this looks like you are trying to use `.. -= ..`, but you really are doing `.. = (- ..)`
|
|
|
|
//~| NOTE to remove this lint, use either `-=` or `= -`
|
|
|
|
a =* &191;
|
|
|
|
//~^ ERROR this looks like you are trying to use `.. *= ..`, but you really are doing `.. = (* ..)`
|
|
|
|
//~| NOTE to remove this lint, use either `*=` or `= *`
|
|
|
|
|
|
|
|
let mut b = true;
|
|
|
|
b =! false;
|
|
|
|
//~^ ERROR this looks like you are trying to use `.. != ..`, but you really are doing `.. = (! ..)`
|
|
|
|
//~| NOTE to remove this lint, use either `!=` or `= !`
|
|
|
|
|
|
|
|
// those are ok:
|
|
|
|
a = -35;
|
|
|
|
a = *&191;
|
|
|
|
b = !false;
|
|
|
|
}
|