2020-04-25 20:01:22 +02:00
|
|
|
// run-rustfix
|
|
|
|
|
2019-05-09 05:55:24 +02:00
|
|
|
#![warn(clippy::while_let_on_iterator)]
|
2020-04-25 20:01:22 +02:00
|
|
|
#![allow(clippy::never_loop, unreachable_code, unused_mut)]
|
2020-05-02 13:18:27 +02:00
|
|
|
#![feature(or_patterns)]
|
2015-10-02 09:55:34 +02:00
|
|
|
|
2020-04-25 20:01:22 +02:00
|
|
|
fn base() {
|
2015-10-22 23:16:58 +02:00
|
|
|
let mut iter = 1..20;
|
2016-06-07 18:33:11 +02:00
|
|
|
while let Option::Some(x) = iter.next() {
|
2015-10-16 20:27:13 +02:00
|
|
|
println!("{}", x);
|
|
|
|
}
|
|
|
|
|
2015-10-22 23:16:58 +02:00
|
|
|
let mut iter = 1..20;
|
2016-06-07 18:33:11 +02:00
|
|
|
while let Some(x) = iter.next() {
|
2015-10-16 20:27:13 +02:00
|
|
|
println!("{}", x);
|
|
|
|
}
|
|
|
|
|
2015-10-22 23:16:58 +02:00
|
|
|
let mut iter = 1..20;
|
2016-06-07 18:33:11 +02:00
|
|
|
while let Some(_) = iter.next() {}
|
2017-02-08 14:58:07 +01: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;
|
2018-12-09 23:26:16 +01:00
|
|
|
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;
|
2020-04-25 20:01:22 +02:00
|
|
|
while let Some(_) = iter.next() {
|
2015-10-20 01:04:21 +02:00
|
|
|
println!("next: {:?}", iter.next())
|
|
|
|
}
|
2015-10-26 23:49:37 +01:00
|
|
|
|
|
|
|
// neither can this
|
|
|
|
let mut iter = 1u32..20;
|
2020-04-25 20:01:22 +02:00
|
|
|
while let Some(_) = iter.next() {
|
2015-10-26 23:49:37 +01:00
|
|
|
println!("next: {:?}", iter.next());
|
|
|
|
}
|
|
|
|
|
|
|
|
// or this
|
|
|
|
let mut iter = 1u32..20;
|
2020-04-25 20:01:22 +02:00
|
|
|
while let Some(_) = iter.next() {
|
2018-12-09 23:26:16 +01:00
|
|
|
break;
|
|
|
|
}
|
2015-10-26 23:49:37 +01:00
|
|
|
println!("Remaining iter {:?}", iter);
|
|
|
|
|
|
|
|
// or this
|
|
|
|
let mut iter = 1u32..20;
|
2020-04-25 20:01:22 +02:00
|
|
|
while let Some(_) = iter.next() {
|
2015-10-26 23:49:37 +01:00
|
|
|
iter = 1..20;
|
|
|
|
}
|
2015-08-29 11:41:06 +02:00
|
|
|
}
|
2015-10-02 09:55:34 +02:00
|
|
|
|
2016-09-16 15:45:44 +02:00
|
|
|
// Issue #1188
|
|
|
|
fn refutable() {
|
|
|
|
let a = [42, 1337];
|
|
|
|
let mut b = a.iter();
|
|
|
|
|
|
|
|
// consume all the 42s
|
2018-12-09 23:26:16 +01:00
|
|
|
while let Some(&42) = b.next() {}
|
2016-09-16 15:45:44 +02:00
|
|
|
|
|
|
|
let a = [(1, 2, 3)];
|
|
|
|
let mut b = a.iter();
|
|
|
|
|
2018-12-09 23:26:16 +01:00
|
|
|
while let Some(&(1, 2, 3)) = b.next() {}
|
2016-09-16 15:45:44 +02:00
|
|
|
|
|
|
|
let a = [Some(42)];
|
|
|
|
let mut b = a.iter();
|
|
|
|
|
2018-12-09 23:26:16 +01:00
|
|
|
while let Some(&None) = b.next() {}
|
2016-09-16 15:45:44 +02: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() {}
|
|
|
|
// */
|
2019-05-06 07:49:45 +02:00
|
|
|
}
|
2017-06-23 18:29:18 +02:00
|
|
|
|
2020-05-02 13:18:27 +02:00
|
|
|
fn refutable2() {
|
|
|
|
// Issue 3780
|
|
|
|
{
|
|
|
|
let v = vec![1, 2, 3];
|
|
|
|
let mut it = v.windows(2);
|
|
|
|
while let Some([x, y]) = it.next() {
|
|
|
|
println!("x: {}", x);
|
|
|
|
println!("y: {}", y);
|
|
|
|
}
|
|
|
|
|
|
|
|
let mut it = v.windows(2);
|
|
|
|
while let Some([x, ..]) = it.next() {
|
|
|
|
println!("x: {}", x);
|
|
|
|
}
|
|
|
|
|
|
|
|
let mut it = v.windows(2);
|
|
|
|
while let Some([.., y]) = it.next() {
|
|
|
|
println!("y: {}", y);
|
|
|
|
}
|
|
|
|
|
|
|
|
let mut it = v.windows(2);
|
|
|
|
while let Some([..]) = it.next() {}
|
|
|
|
|
|
|
|
let v = vec![[1], [2], [3]];
|
|
|
|
let mut it = v.iter();
|
|
|
|
while let Some([1]) = it.next() {}
|
|
|
|
|
|
|
|
let mut it = v.iter();
|
|
|
|
while let Some([_x]) = it.next() {}
|
|
|
|
}
|
|
|
|
|
|
|
|
// binding
|
|
|
|
{
|
|
|
|
let v = vec![1, 2, 3];
|
|
|
|
let mut it = v.iter();
|
|
|
|
while let Some(x @ 1) = it.next() {
|
|
|
|
println!("{}", x);
|
|
|
|
}
|
|
|
|
|
|
|
|
let v = vec![[1], [2], [3]];
|
|
|
|
let mut it = v.iter();
|
|
|
|
while let Some(x @ [_]) = it.next() {
|
|
|
|
println!("{:?}", x);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// false negative
|
|
|
|
{
|
|
|
|
let v = vec![1, 2, 3];
|
|
|
|
let mut it = v.iter().map(Some);
|
|
|
|
while let Some(Some(_) | None) = it.next() {
|
|
|
|
println!("1");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-05-06 07:49:45 +02:00
|
|
|
fn nested_loops() {
|
|
|
|
let a = [42, 1337];
|
2017-06-30 02:43:52 +02:00
|
|
|
let mut y = a.iter();
|
2018-12-09 23:26:16 +01:00
|
|
|
loop {
|
|
|
|
// x is reused, so don't lint here
|
2020-04-25 20:01:22 +02:00
|
|
|
while let Some(_) = y.next() {}
|
2017-06-23 18:29:18 +02:00
|
|
|
}
|
|
|
|
|
2017-06-30 02:43:52 +02:00
|
|
|
let mut y = a.iter();
|
2017-06-23 18:29:18 +02:00
|
|
|
for _ in 0..2 {
|
2020-04-25 20:01:22 +02:00
|
|
|
while let Some(_) = y.next() {
|
2018-12-09 23:26:16 +01:00
|
|
|
// y is reused, don't lint
|
2017-08-01 00:58:26 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
loop {
|
|
|
|
let mut y = a.iter();
|
2020-04-25 20:01:22 +02:00
|
|
|
while let Some(_) = y.next() {
|
2018-12-09 23:26:16 +01:00
|
|
|
// use a for loop here
|
2017-06-23 18:29:18 +02:00
|
|
|
}
|
|
|
|
}
|
2019-05-06 07:49:45 +02:00
|
|
|
}
|
2017-09-05 22:28:30 +02:00
|
|
|
|
2019-05-06 07:49:45 +02:00
|
|
|
fn issue1121() {
|
2018-01-29 16:52:22 +01:00
|
|
|
use std::collections::HashSet;
|
|
|
|
let mut values = HashSet::new();
|
|
|
|
values.insert(1);
|
|
|
|
|
|
|
|
while let Some(&value) = values.iter().next() {
|
|
|
|
values.remove(&value);
|
|
|
|
}
|
2019-05-06 07:49:45 +02:00
|
|
|
}
|
2018-07-28 11:51:46 +02:00
|
|
|
|
2019-05-06 07:49:45 +02:00
|
|
|
fn issue2965() {
|
2018-07-28 11:51:46 +02:00
|
|
|
// This should not cause an ICE and suggest:
|
|
|
|
//
|
|
|
|
// for _ in values.iter() {}
|
|
|
|
//
|
2019-05-06 07:49:45 +02:00
|
|
|
use std::collections::HashSet;
|
|
|
|
let mut values = HashSet::new();
|
|
|
|
values.insert(1);
|
|
|
|
|
2020-04-25 20:51:23 +02:00
|
|
|
while let Some(..) = values.iter().next() {}
|
2019-05-06 07:49:45 +02:00
|
|
|
}
|
2019-01-19 10:36:27 +01:00
|
|
|
|
2019-05-06 07:49:45 +02:00
|
|
|
fn issue3670() {
|
|
|
|
let array = [Some(0), None, Some(1)];
|
|
|
|
let mut iter = array.iter();
|
2019-01-19 10:36:27 +01:00
|
|
|
|
2019-05-06 07:49:45 +02:00
|
|
|
while let Some(elem) = iter.next() {
|
|
|
|
let _ = elem.or_else(|| *iter.next()?);
|
2019-01-19 10:36:27 +01:00
|
|
|
}
|
2016-09-16 15:45:44 +02:00
|
|
|
}
|
2020-04-25 20:01:22 +02:00
|
|
|
|
2020-04-25 20:51:23 +02:00
|
|
|
fn issue1654() {
|
|
|
|
// should not lint if the iterator is generated on every iteration
|
|
|
|
use std::collections::HashSet;
|
|
|
|
let mut values = HashSet::new();
|
|
|
|
values.insert(1);
|
|
|
|
|
|
|
|
while let Some(..) = values.iter().next() {
|
|
|
|
values.remove(&1);
|
|
|
|
}
|
|
|
|
|
|
|
|
while let Some(..) = values.iter().map(|x| x + 1).next() {}
|
|
|
|
|
|
|
|
let chars = "Hello, World!".char_indices();
|
|
|
|
while let Some((i, ch)) = chars.clone().next() {
|
|
|
|
println!("{}: {}", i, ch);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-04-25 20:01:22 +02:00
|
|
|
fn main() {
|
|
|
|
base();
|
|
|
|
refutable();
|
2020-05-02 13:18:27 +02:00
|
|
|
refutable2();
|
2020-04-25 20:01:22 +02:00
|
|
|
nested_loops();
|
|
|
|
issue1121();
|
|
|
|
issue2965();
|
|
|
|
issue3670();
|
2020-04-25 20:51:23 +02:00
|
|
|
issue1654();
|
2020-04-25 20:01:22 +02:00
|
|
|
}
|