2015-08-29 11:41:06 +02:00
|
|
|
#![feature(plugin)]
|
|
|
|
#![plugin(clippy)]
|
|
|
|
|
2015-10-16 20:27:13 +02:00
|
|
|
#![deny(while_let_loop, empty_loop, while_let_on_iterator)]
|
2015-11-18 12:35:18 +01:00
|
|
|
#![allow(dead_code, unused, cyclomatic_complexity)]
|
2015-10-02 09:55:34 +02:00
|
|
|
|
2015-08-29 11:41:06 +02:00
|
|
|
fn main() {
|
|
|
|
let y = Some(true);
|
2016-02-24 20:54:35 +01:00
|
|
|
loop {
|
|
|
|
//~^ERROR this loop could be written as a `while let` loop
|
|
|
|
//~|HELP try
|
|
|
|
//~|SUGGESTION while let Some(_x) = y {
|
2015-08-29 11:41:06 +02:00
|
|
|
if let Some(_x) = y {
|
|
|
|
let _v = 1;
|
|
|
|
} else {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
loop { // no error, break is not in else clause
|
|
|
|
if let Some(_x) = y {
|
|
|
|
let _v = 1;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
2016-02-24 20:54:35 +01:00
|
|
|
loop {
|
|
|
|
//~^ERROR this loop could be written as a `while let` loop
|
|
|
|
//~|HELP try
|
|
|
|
//~|SUGGESTION while let Some(_x) = y {
|
2015-08-29 11:41:06 +02:00
|
|
|
match y {
|
|
|
|
Some(_x) => true,
|
|
|
|
None => break
|
|
|
|
};
|
|
|
|
}
|
2016-02-24 20:54:35 +01:00
|
|
|
loop {
|
|
|
|
//~^ERROR this loop could be written as a `while let` loop
|
|
|
|
//~|HELP try
|
|
|
|
//~|SUGGESTION while let Some(x) = y {
|
2015-09-27 09:39:42 +02:00
|
|
|
let x = match y {
|
|
|
|
Some(x) => x,
|
2015-08-29 11:41:06 +02:00
|
|
|
None => break
|
|
|
|
};
|
2015-09-27 09:39:42 +02:00
|
|
|
let _x = x;
|
|
|
|
let _str = "foo";
|
2015-08-29 11:41:06 +02:00
|
|
|
}
|
2016-02-24 20:54:35 +01:00
|
|
|
loop {
|
|
|
|
//~^ERROR this loop could be written as a `while let` loop
|
|
|
|
//~|HELP try
|
|
|
|
//~|SUGGESTION while let Some(x) = y {
|
2015-10-11 18:49:01 +02:00
|
|
|
let x = match y {
|
|
|
|
Some(x) => x,
|
|
|
|
None => break,
|
|
|
|
};
|
|
|
|
{ let _a = "bar"; };
|
|
|
|
{ let _b = "foobar"; }
|
|
|
|
}
|
2015-08-29 11:41:06 +02:00
|
|
|
loop { // no error, else branch does something other than break
|
|
|
|
match y {
|
|
|
|
Some(_x) => true,
|
|
|
|
_ => {
|
|
|
|
let _z = 1;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
while let Some(x) = y { // no error, obviously
|
|
|
|
println!("{}", x);
|
|
|
|
}
|
2015-10-16 20:27:13 +02:00
|
|
|
|
2016-02-27 22:59:15 +01:00
|
|
|
// #675, this used to have a wrong suggestion
|
|
|
|
loop {
|
|
|
|
//~^ERROR this loop could be written as a `while let` loop
|
|
|
|
//~|HELP try
|
|
|
|
//~|SUGGESTION while let Some(word) = "".split_whitespace().next() { .. }
|
|
|
|
let (e, l) = match "".split_whitespace().next() {
|
|
|
|
Some(word) => (word.is_empty(), word.len()),
|
|
|
|
None => break
|
|
|
|
};
|
|
|
|
|
|
|
|
let _ = (e, l);
|
|
|
|
}
|
|
|
|
|
2015-10-22 23:16:58 +02:00
|
|
|
let mut iter = 1..20;
|
|
|
|
while let Option::Some(x) = iter.next() { //~ERROR this loop could be written as a `for` loop
|
2015-10-16 20:27:13 +02:00
|
|
|
println!("{}", x);
|
|
|
|
}
|
|
|
|
|
2015-10-22 23:16:58 +02:00
|
|
|
let mut iter = 1..20;
|
|
|
|
while let Some(x) = iter.next() { //~ERROR this loop could be written as a `for` loop
|
2015-10-16 20:27:13 +02:00
|
|
|
println!("{}", x);
|
|
|
|
}
|
|
|
|
|
2015-10-22 23:16:58 +02:00
|
|
|
let mut iter = 1..20;
|
|
|
|
while let Some(_) = iter.next() {} //~ERROR this loop could be written as a `for` loop
|
2015-10-16 20:27:13 +02:00
|
|
|
|
2015-10-22 23:16:58 +02:00
|
|
|
let mut iter = 1..20;
|
|
|
|
while let None = iter.next() {} // this is fine (if nonsensical)
|
2015-10-16 20:27:13 +02:00
|
|
|
|
2015-10-22 23:16:58 +02:00
|
|
|
let mut iter = 1..20;
|
|
|
|
if let Some(x) = iter.next() { // also fine
|
2015-10-16 20:27:13 +02:00
|
|
|
println!("{}", x)
|
|
|
|
}
|
2015-10-20 01:04:21 +02:00
|
|
|
|
|
|
|
// the following shouldn't warn because it can't be written with a for loop
|
|
|
|
let mut iter = 1u32..20;
|
|
|
|
while let Some(x) = iter.next() {
|
|
|
|
println!("next: {:?}", iter.next())
|
|
|
|
}
|
2015-10-26 23:49:37 +01:00
|
|
|
|
|
|
|
// neither can this
|
|
|
|
let mut iter = 1u32..20;
|
|
|
|
while let Some(x) = iter.next() {
|
|
|
|
println!("next: {:?}", iter.next());
|
|
|
|
}
|
|
|
|
|
|
|
|
// or this
|
|
|
|
let mut iter = 1u32..20;
|
|
|
|
while let Some(x) = iter.next() {break;}
|
|
|
|
println!("Remaining iter {:?}", iter);
|
|
|
|
|
|
|
|
// or this
|
|
|
|
let mut iter = 1u32..20;
|
|
|
|
while let Some(x) = iter.next() {
|
|
|
|
iter = 1..20;
|
|
|
|
}
|
2015-08-29 11:41:06 +02:00
|
|
|
}
|
2015-10-02 09:55:34 +02:00
|
|
|
|
|
|
|
// regression test (#360)
|
|
|
|
// this should not panic
|
|
|
|
// it's okay if further iterations of the lint
|
|
|
|
// cause this function to trigger it
|
|
|
|
fn no_panic<T>(slice: &[T]) {
|
|
|
|
let mut iter = slice.iter();
|
2015-10-11 18:49:01 +02:00
|
|
|
loop { //~ERROR
|
2015-10-02 09:55:34 +02:00
|
|
|
let _ = match iter.next() {
|
|
|
|
Some(ele) => ele,
|
|
|
|
None => break
|
|
|
|
};
|
2015-10-12 13:38:18 +02:00
|
|
|
loop {} //~ERROR empty `loop {}` detected.
|
2015-10-02 09:55:34 +02:00
|
|
|
}
|
|
|
|
}
|