2023-04-20 14:37:15 +00:00
|
|
|
//@aux-build:option_helpers.rs
|
2021-03-12 15:30:50 +01:00
|
|
|
|
|
|
|
#![warn(clippy::iter_count)]
|
|
|
|
#![allow(
|
2021-06-18 16:20:30 +08:00
|
|
|
unused_variables,
|
|
|
|
array_into_iter,
|
|
|
|
unused_mut,
|
|
|
|
clippy::into_iter_on_ref,
|
2023-06-06 22:56:57 +02:00
|
|
|
clippy::unnecessary_operation,
|
|
|
|
clippy::useless_vec
|
2021-03-12 15:30:50 +01:00
|
|
|
)]
|
|
|
|
|
|
|
|
extern crate option_helpers;
|
|
|
|
|
|
|
|
use option_helpers::IteratorFalsePositives;
|
|
|
|
use std::collections::{BTreeMap, BTreeSet, BinaryHeap, HashMap, HashSet, LinkedList, VecDeque};
|
|
|
|
|
|
|
|
/// Struct to generate false positives for things with `.iter()`.
|
|
|
|
#[derive(Copy, Clone)]
|
|
|
|
struct HasIter;
|
|
|
|
|
|
|
|
impl HasIter {
|
|
|
|
fn iter(self) -> IteratorFalsePositives {
|
|
|
|
IteratorFalsePositives { foo: 0 }
|
|
|
|
}
|
|
|
|
|
|
|
|
fn iter_mut(self) -> IteratorFalsePositives {
|
|
|
|
IteratorFalsePositives { foo: 0 }
|
|
|
|
}
|
|
|
|
|
|
|
|
fn into_iter(self) -> IteratorFalsePositives {
|
|
|
|
IteratorFalsePositives { foo: 0 }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-10-11 16:15:50 -04:00
|
|
|
#[allow(unused_must_use)]
|
2021-03-12 15:30:50 +01:00
|
|
|
fn main() {
|
|
|
|
let mut vec = vec![0, 1, 2, 3];
|
|
|
|
let mut boxed_slice: Box<[u8]> = Box::new([0, 1, 2, 3]);
|
|
|
|
let mut vec_deque: VecDeque<_> = vec.iter().cloned().collect();
|
|
|
|
let mut hash_set = HashSet::new();
|
|
|
|
let mut hash_map = HashMap::new();
|
|
|
|
let mut b_tree_map = BTreeMap::new();
|
|
|
|
let mut b_tree_set = BTreeSet::new();
|
|
|
|
let mut linked_list = LinkedList::new();
|
|
|
|
let mut binary_heap = BinaryHeap::new();
|
|
|
|
hash_set.insert(1);
|
|
|
|
hash_map.insert(1, 2);
|
|
|
|
b_tree_map.insert(1, 2);
|
|
|
|
b_tree_set.insert(1);
|
|
|
|
linked_list.push_back(1);
|
|
|
|
binary_heap.push(1);
|
|
|
|
|
2021-10-11 16:15:50 -04:00
|
|
|
&vec[..].iter().count();
|
2021-03-12 15:30:50 +01:00
|
|
|
vec.iter().count();
|
|
|
|
boxed_slice.iter().count();
|
|
|
|
vec_deque.iter().count();
|
|
|
|
hash_set.iter().count();
|
|
|
|
hash_map.iter().count();
|
|
|
|
b_tree_map.iter().count();
|
|
|
|
b_tree_set.iter().count();
|
|
|
|
linked_list.iter().count();
|
|
|
|
binary_heap.iter().count();
|
|
|
|
|
|
|
|
vec.iter_mut().count();
|
2021-10-11 16:15:50 -04:00
|
|
|
&vec[..].iter_mut().count();
|
2021-03-12 15:30:50 +01:00
|
|
|
vec_deque.iter_mut().count();
|
|
|
|
hash_map.iter_mut().count();
|
|
|
|
b_tree_map.iter_mut().count();
|
|
|
|
linked_list.iter_mut().count();
|
|
|
|
|
2021-10-11 16:15:50 -04:00
|
|
|
&vec[..].into_iter().count();
|
2021-03-12 15:30:50 +01:00
|
|
|
vec.into_iter().count();
|
|
|
|
vec_deque.into_iter().count();
|
|
|
|
hash_set.into_iter().count();
|
|
|
|
hash_map.into_iter().count();
|
|
|
|
b_tree_map.into_iter().count();
|
|
|
|
b_tree_set.into_iter().count();
|
|
|
|
linked_list.into_iter().count();
|
|
|
|
binary_heap.into_iter().count();
|
|
|
|
|
|
|
|
// Make sure we don't lint for non-relevant types.
|
|
|
|
let false_positive = HasIter;
|
|
|
|
false_positive.iter().count();
|
|
|
|
false_positive.iter_mut().count();
|
|
|
|
false_positive.into_iter().count();
|
|
|
|
}
|