2018-07-28 15:34:52 +00:00
|
|
|
#![warn(clippy::while_let_loop, clippy::empty_loop, clippy::while_let_on_iterator)]
|
2019-02-23 01:19:50 +00:00
|
|
|
#![allow(dead_code, clippy::never_loop, unused, clippy::cognitive_complexity)]
|
2015-10-02 07:55:34 +00:00
|
|
|
|
2015-08-29 09:41:06 +00:00
|
|
|
fn main() {
|
|
|
|
let y = Some(true);
|
2016-02-24 19:54:35 +00:00
|
|
|
loop {
|
2015-08-29 09:41:06 +00:00
|
|
|
if let Some(_x) = y {
|
|
|
|
let _v = 1;
|
|
|
|
} else {
|
2018-12-09 22:26:16 +00:00
|
|
|
break;
|
2015-08-29 09:41:06 +00:00
|
|
|
}
|
|
|
|
}
|
2018-12-09 22:26:16 +00:00
|
|
|
loop {
|
|
|
|
// no error, break is not in else clause
|
2015-08-29 09:41:06 +00:00
|
|
|
if let Some(_x) = y {
|
|
|
|
let _v = 1;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
2016-02-24 19:54:35 +00:00
|
|
|
loop {
|
2015-08-29 09:41:06 +00:00
|
|
|
match y {
|
|
|
|
Some(_x) => true,
|
2018-12-09 22:26:16 +00:00
|
|
|
None => break,
|
2015-08-29 09:41:06 +00:00
|
|
|
};
|
|
|
|
}
|
2016-02-24 19:54:35 +00:00
|
|
|
loop {
|
2015-09-27 07:39:42 +00:00
|
|
|
let x = match y {
|
|
|
|
Some(x) => x,
|
2018-12-09 22:26:16 +00:00
|
|
|
None => break,
|
2015-08-29 09:41:06 +00:00
|
|
|
};
|
2015-09-27 07:39:42 +00:00
|
|
|
let _x = x;
|
|
|
|
let _str = "foo";
|
2015-08-29 09:41:06 +00:00
|
|
|
}
|
2016-02-24 19:54:35 +00:00
|
|
|
loop {
|
2015-10-11 16:49:01 +00:00
|
|
|
let x = match y {
|
|
|
|
Some(x) => x,
|
|
|
|
None => break,
|
|
|
|
};
|
2018-12-09 22:26:16 +00:00
|
|
|
{
|
|
|
|
let _a = "bar";
|
|
|
|
};
|
|
|
|
{
|
|
|
|
let _b = "foobar";
|
|
|
|
}
|
2015-10-11 16:49:01 +00:00
|
|
|
}
|
2018-12-09 22:26:16 +00:00
|
|
|
loop {
|
|
|
|
// no error, else branch does something other than break
|
2015-08-29 09:41:06 +00:00
|
|
|
match y {
|
|
|
|
Some(_x) => true,
|
|
|
|
_ => {
|
|
|
|
let _z = 1;
|
|
|
|
break;
|
2018-12-09 22:26:16 +00:00
|
|
|
},
|
2015-08-29 09:41:06 +00:00
|
|
|
};
|
|
|
|
}
|
2018-12-09 22:26:16 +00:00
|
|
|
while let Some(x) = y {
|
|
|
|
// no error, obviously
|
2015-08-29 09:41:06 +00:00
|
|
|
println!("{}", x);
|
|
|
|
}
|
2015-10-16 18:27:13 +00:00
|
|
|
|
2016-02-27 21:59:15 +00:00
|
|
|
// #675, this used to have a wrong suggestion
|
|
|
|
loop {
|
|
|
|
let (e, l) = match "".split_whitespace().next() {
|
|
|
|
Some(word) => (word.is_empty(), word.len()),
|
2018-12-09 22:26:16 +00:00
|
|
|
None => break,
|
2016-02-27 21:59:15 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
let _ = (e, l);
|
|
|
|
}
|
|
|
|
|
2015-10-22 21:16:58 +00:00
|
|
|
let mut iter = 1..20;
|
2016-06-07 16:33:11 +00:00
|
|
|
while let Option::Some(x) = iter.next() {
|
2015-10-16 18:27:13 +00:00
|
|
|
println!("{}", x);
|
|
|
|
}
|
|
|
|
|
2015-10-22 21:16:58 +00:00
|
|
|
let mut iter = 1..20;
|
2016-06-07 16:33:11 +00:00
|
|
|
while let Some(x) = iter.next() {
|
2015-10-16 18:27:13 +00:00
|
|
|
println!("{}", x);
|
|
|
|
}
|
|
|
|
|
2015-10-22 21:16:58 +00:00
|
|
|
let mut iter = 1..20;
|
2016-06-07 16:33:11 +00:00
|
|
|
while let Some(_) = iter.next() {}
|
2017-02-08 13:58:07 +00:00
|
|
|
|
2015-10-22 21:16:58 +00:00
|
|
|
let mut iter = 1..20;
|
|
|
|
while let None = iter.next() {} // this is fine (if nonsensical)
|
2015-10-16 18:27:13 +00:00
|
|
|
|
2015-10-22 21:16:58 +00:00
|
|
|
let mut iter = 1..20;
|
2018-12-09 22:26:16 +00:00
|
|
|
if let Some(x) = iter.next() {
|
|
|
|
// also fine
|
2015-10-16 18:27:13 +00:00
|
|
|
println!("{}", x)
|
|
|
|
}
|
2015-10-19 23:04:21 +00: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 22:49:37 +00: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;
|
2018-12-09 22:26:16 +00:00
|
|
|
while let Some(x) = iter.next() {
|
|
|
|
break;
|
|
|
|
}
|
2015-10-26 22:49:37 +00:00
|
|
|
println!("Remaining iter {:?}", iter);
|
|
|
|
|
|
|
|
// or this
|
|
|
|
let mut iter = 1u32..20;
|
|
|
|
while let Some(x) = iter.next() {
|
|
|
|
iter = 1..20;
|
|
|
|
}
|
2015-08-29 09:41:06 +00:00
|
|
|
}
|
2015-10-02 07:55:34 +00:00
|
|
|
|
|
|
|
// regression test (#360)
|
|
|
|
// this should not panic
|
2019-01-31 01:15:29 +00:00
|
|
|
// it's ok if further iterations of the lint
|
2015-10-02 07:55:34 +00:00
|
|
|
// cause this function to trigger it
|
|
|
|
fn no_panic<T>(slice: &[T]) {
|
|
|
|
let mut iter = slice.iter();
|
2016-06-07 16:33:11 +00:00
|
|
|
loop {
|
2015-10-02 07:55:34 +00:00
|
|
|
let _ = match iter.next() {
|
|
|
|
Some(ele) => ele,
|
2018-12-09 22:26:16 +00:00
|
|
|
None => break,
|
2015-10-02 07:55:34 +00:00
|
|
|
};
|
2017-02-08 13:58:07 +00:00
|
|
|
loop {}
|
2015-10-02 07:55:34 +00:00
|
|
|
}
|
|
|
|
}
|
2016-06-16 14:19:17 +00:00
|
|
|
|
|
|
|
fn issue1017() {
|
|
|
|
let r: Result<u32, u32> = Ok(42);
|
|
|
|
let mut len = 1337;
|
|
|
|
|
|
|
|
loop {
|
|
|
|
match r {
|
|
|
|
Err(_) => len = 0,
|
|
|
|
Ok(length) => {
|
|
|
|
len = length;
|
2018-12-09 22:26:16 +00:00
|
|
|
break;
|
|
|
|
},
|
2016-06-16 14:19:17 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2016-09-16 13:45:44 +00:00
|
|
|
|
|
|
|
// Issue #1188
|
|
|
|
fn refutable() {
|
|
|
|
let a = [42, 1337];
|
|
|
|
let mut b = a.iter();
|
|
|
|
|
|
|
|
// consume all the 42s
|
2018-12-09 22:26:16 +00:00
|
|
|
while let Some(&42) = b.next() {}
|
2016-09-16 13:45:44 +00:00
|
|
|
|
|
|
|
let a = [(1, 2, 3)];
|
|
|
|
let mut b = a.iter();
|
|
|
|
|
2018-12-09 22:26:16 +00:00
|
|
|
while let Some(&(1, 2, 3)) = b.next() {}
|
2016-09-16 13:45:44 +00:00
|
|
|
|
|
|
|
let a = [Some(42)];
|
|
|
|
let mut b = a.iter();
|
|
|
|
|
2018-12-09 22:26:16 +00:00
|
|
|
while let Some(&None) = b.next() {}
|
2016-09-16 13:45:44 +00:00
|
|
|
|
|
|
|
/* This gives “refutable pattern in `for` loop binding: `&_` not covered”
|
|
|
|
for &42 in b {}
|
|
|
|
for &(1, 2, 3) in b {}
|
|
|
|
for &Option::None in b.next() {}
|
|
|
|
// */
|
2017-06-23 16:29:18 +00:00
|
|
|
|
2017-06-30 00:43:52 +00:00
|
|
|
let mut y = a.iter();
|
2018-12-09 22:26:16 +00:00
|
|
|
loop {
|
|
|
|
// x is reused, so don't lint here
|
|
|
|
while let Some(v) = y.next() {}
|
2017-06-23 16:29:18 +00:00
|
|
|
}
|
|
|
|
|
2017-06-30 00:43:52 +00:00
|
|
|
let mut y = a.iter();
|
2017-06-23 16:29:18 +00:00
|
|
|
for _ in 0..2 {
|
2018-12-09 22:26:16 +00:00
|
|
|
while let Some(v) = y.next() {
|
|
|
|
// y is reused, don't lint
|
2017-07-31 22:58:26 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
loop {
|
|
|
|
let mut y = a.iter();
|
2018-12-09 22:26:16 +00:00
|
|
|
while let Some(v) = y.next() {
|
|
|
|
// use a for loop here
|
2017-06-23 16:29:18 +00:00
|
|
|
}
|
|
|
|
}
|
2017-09-05 20:28:30 +00:00
|
|
|
|
2018-07-28 15:34:52 +00:00
|
|
|
// should not trigger clippy::while_let_loop lint because break passes an expression
|
2017-09-05 20:28:30 +00:00
|
|
|
let a = Some(10);
|
|
|
|
let b = loop {
|
|
|
|
if let Some(c) = a {
|
|
|
|
break Some(c);
|
|
|
|
} else {
|
|
|
|
break None;
|
|
|
|
}
|
|
|
|
};
|
2018-01-29 15:52:22 +00:00
|
|
|
|
|
|
|
use std::collections::HashSet;
|
|
|
|
let mut values = HashSet::new();
|
|
|
|
values.insert(1);
|
|
|
|
|
|
|
|
while let Some(&value) = values.iter().next() {
|
|
|
|
values.remove(&value);
|
|
|
|
}
|
2018-07-28 09:51:46 +00:00
|
|
|
|
|
|
|
// This should not cause an ICE and suggest:
|
|
|
|
//
|
|
|
|
// for _ in values.iter() {}
|
|
|
|
//
|
|
|
|
// See #2965
|
|
|
|
while let Some(..) = values.iter().next() {
|
|
|
|
values.remove(&1);
|
|
|
|
}
|
2019-01-19 09:36:27 +00:00
|
|
|
|
|
|
|
// Issue 3670
|
|
|
|
{
|
|
|
|
let array = [Some(0), None, Some(1)];
|
|
|
|
let mut iter = array.iter();
|
|
|
|
|
|
|
|
while let Some(elem) = iter.next() {
|
|
|
|
let _ = elem.or_else(|| *iter.next()?);
|
|
|
|
}
|
|
|
|
}
|
2016-09-16 13:45:44 +00:00
|
|
|
}
|