2023-04-20 14:37:15 +00:00
|
|
|
//@aux-build:option_helpers.rs
|
2020-01-20 10:54:54 +09:00
|
|
|
|
|
|
|
#![warn(clippy::skip_while_next)]
|
2023-06-06 22:56:57 +02:00
|
|
|
#![allow(clippy::disallowed_names, clippy::useless_vec)]
|
2020-01-20 10:54:54 +09:00
|
|
|
|
|
|
|
extern crate option_helpers;
|
|
|
|
use option_helpers::IteratorFalsePositives;
|
|
|
|
|
|
|
|
#[rustfmt::skip]
|
|
|
|
fn skip_while_next() {
|
|
|
|
let v = vec![3, 2, 1, 0, -1, -2, -3];
|
|
|
|
|
|
|
|
// Single-line case.
|
|
|
|
let _ = v.iter().skip_while(|&x| *x < 0).next();
|
|
|
|
|
|
|
|
// Multi-line case.
|
|
|
|
let _ = v.iter().skip_while(|&x| {
|
|
|
|
*x < 0
|
|
|
|
}
|
|
|
|
).next();
|
|
|
|
|
|
|
|
// Check that hat we don't lint if the caller is not an `Iterator`.
|
|
|
|
let foo = IteratorFalsePositives { foo: 0 };
|
|
|
|
let _ = foo.skip_while().next();
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
skip_while_next();
|
|
|
|
}
|