2020-05-15 18:20:07 +02:00
|
|
|
#![warn(clippy::for_loops_over_fallibles)]
|
2018-10-30 21:25:34 +01:00
|
|
|
|
2020-05-15 18:20:07 +02:00
|
|
|
fn for_loops_over_fallibles() {
|
2018-10-30 21:25:34 +01:00
|
|
|
let option = Some(1);
|
|
|
|
let result = option.ok_or("x not found");
|
|
|
|
let v = vec![0, 1, 2];
|
|
|
|
|
2020-05-03 15:16:00 +02:00
|
|
|
// check over an `Option`
|
2018-10-30 21:25:34 +01:00
|
|
|
for x in option {
|
|
|
|
println!("{}", x);
|
|
|
|
}
|
|
|
|
|
2020-05-03 15:16:00 +02:00
|
|
|
// check over a `Result`
|
2018-10-30 21:25:34 +01:00
|
|
|
for x in result {
|
|
|
|
println!("{}", x);
|
|
|
|
}
|
|
|
|
|
|
|
|
for x in option.ok_or("x not found") {
|
|
|
|
println!("{}", x);
|
|
|
|
}
|
|
|
|
|
|
|
|
// make sure LOOP_OVER_NEXT lint takes clippy::precedence when next() is the last call
|
|
|
|
// in the chain
|
|
|
|
for x in v.iter().next() {
|
|
|
|
println!("{}", x);
|
|
|
|
}
|
|
|
|
|
|
|
|
// make sure we lint when next() is not the last call in the chain
|
|
|
|
for x in v.iter().next().and(Some(0)) {
|
|
|
|
println!("{}", x);
|
|
|
|
}
|
|
|
|
|
|
|
|
for x in v.iter().next().ok_or("x not found") {
|
|
|
|
println!("{}", x);
|
|
|
|
}
|
|
|
|
|
|
|
|
// check for false positives
|
|
|
|
|
|
|
|
// for loop false positive
|
|
|
|
for x in v {
|
|
|
|
println!("{}", x);
|
|
|
|
}
|
|
|
|
|
|
|
|
// while let false positive for Option
|
|
|
|
while let Some(x) = option {
|
|
|
|
println!("{}", x);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
// while let false positive for Result
|
|
|
|
while let Ok(x) = result {
|
|
|
|
println!("{}", x);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {}
|