mirror of
https://github.com/rust-lang/rust-clippy
synced 2024-12-11 22:02:55 +00:00
be55a96d80
This commit adds a config flag for enforcing explicit into iter lint for reborrowed values. The config flag, enforce_iter_loop_reborrow, can be added to clippy.toml files to enable the linting behaviour. By default the lint is not enabled.
154 lines
3.6 KiB
Rust
154 lines
3.6 KiB
Rust
#![deny(clippy::explicit_iter_loop)]
|
|
#![allow(
|
|
clippy::linkedlist,
|
|
clippy::similar_names,
|
|
clippy::needless_borrow,
|
|
clippy::deref_addrof,
|
|
clippy::unnecessary_mut_passed,
|
|
dead_code
|
|
)]
|
|
|
|
use core::slice;
|
|
use std::collections::*;
|
|
|
|
fn main() {
|
|
let mut vec = vec![1, 2, 3, 4];
|
|
|
|
for _ in &vec {}
|
|
for _ in &mut vec {}
|
|
|
|
let rvec = &vec;
|
|
for _ in rvec {}
|
|
|
|
let rmvec = &mut vec;
|
|
for _ in rmvec.iter() {}
|
|
for _ in rmvec.iter_mut() {}
|
|
|
|
for _ in &vec {} // these are fine
|
|
for _ in &mut vec {} // these are fine
|
|
|
|
for _ in &[1, 2, 3] {}
|
|
|
|
for _ in (&mut [1, 2, 3]).iter() {}
|
|
|
|
for _ in &[0; 32] {}
|
|
for _ in &[0; 33] {}
|
|
|
|
let ll: LinkedList<()> = LinkedList::new();
|
|
for _ in &ll {}
|
|
let rll = ≪
|
|
for _ in rll {}
|
|
|
|
let vd: VecDeque<()> = VecDeque::new();
|
|
for _ in &vd {}
|
|
let rvd = &vd;
|
|
for _ in rvd {}
|
|
|
|
let bh: BinaryHeap<()> = BinaryHeap::new();
|
|
for _ in &bh {}
|
|
|
|
let hm: HashMap<(), ()> = HashMap::new();
|
|
for _ in &hm {}
|
|
|
|
let bt: BTreeMap<(), ()> = BTreeMap::new();
|
|
for _ in &bt {}
|
|
|
|
let hs: HashSet<()> = HashSet::new();
|
|
for _ in &hs {}
|
|
|
|
let bs: BTreeSet<()> = BTreeSet::new();
|
|
for _ in &bs {}
|
|
|
|
struct NoIntoIter();
|
|
impl NoIntoIter {
|
|
fn iter(&self) -> slice::Iter<u8> {
|
|
unimplemented!()
|
|
}
|
|
|
|
fn iter_mut(&mut self) -> slice::IterMut<u8> {
|
|
unimplemented!()
|
|
}
|
|
}
|
|
let mut x = NoIntoIter();
|
|
for _ in x.iter() {} // no error
|
|
for _ in x.iter_mut() {} // no error
|
|
|
|
struct IntoIterDiffTy;
|
|
impl IntoIterator for &'_ IntoIterDiffTy {
|
|
type Item = &'static ();
|
|
type IntoIter = core::slice::Iter<'static, ()>;
|
|
fn into_iter(self) -> Self::IntoIter {
|
|
unimplemented!()
|
|
}
|
|
}
|
|
impl IntoIterDiffTy {
|
|
fn iter(&self) -> core::slice::Iter<'static, i32> {
|
|
unimplemented!()
|
|
}
|
|
}
|
|
let x = IntoIterDiffTy;
|
|
for _ in x.iter() {}
|
|
|
|
struct IntoIterDiffSig;
|
|
impl IntoIterator for &'_ IntoIterDiffSig {
|
|
type Item = &'static ();
|
|
type IntoIter = core::slice::Iter<'static, ()>;
|
|
fn into_iter(self) -> Self::IntoIter {
|
|
unimplemented!()
|
|
}
|
|
}
|
|
impl IntoIterDiffSig {
|
|
fn iter(&self, _: u32) -> core::slice::Iter<'static, ()> {
|
|
unimplemented!()
|
|
}
|
|
}
|
|
let x = IntoIterDiffSig;
|
|
for _ in x.iter(0) {}
|
|
|
|
struct IntoIterDiffLt<'a>(&'a ());
|
|
impl<'a> IntoIterator for &'a IntoIterDiffLt<'_> {
|
|
type Item = &'a ();
|
|
type IntoIter = core::slice::Iter<'a, ()>;
|
|
fn into_iter(self) -> Self::IntoIter {
|
|
unimplemented!()
|
|
}
|
|
}
|
|
impl<'a> IntoIterDiffLt<'a> {
|
|
fn iter(&self) -> core::slice::Iter<'a, ()> {
|
|
unimplemented!()
|
|
}
|
|
}
|
|
let x = IntoIterDiffLt(&());
|
|
for _ in x.iter() {}
|
|
|
|
struct CustomType;
|
|
impl<'a> IntoIterator for &'a CustomType {
|
|
type Item = &'a u32;
|
|
type IntoIter = core::slice::Iter<'a, u32>;
|
|
fn into_iter(self) -> Self::IntoIter {
|
|
unimplemented!()
|
|
}
|
|
}
|
|
impl<'a> IntoIterator for &'a mut CustomType {
|
|
type Item = &'a mut u32;
|
|
type IntoIter = core::slice::IterMut<'a, u32>;
|
|
fn into_iter(self) -> Self::IntoIter {
|
|
unimplemented!()
|
|
}
|
|
}
|
|
impl CustomType {
|
|
fn iter(&self) -> <&'_ Self as IntoIterator>::IntoIter {
|
|
panic!()
|
|
}
|
|
|
|
fn iter_mut(&mut self) -> core::slice::IterMut<'_, u32> {
|
|
panic!()
|
|
}
|
|
}
|
|
let mut x = CustomType;
|
|
for _ in &x {}
|
|
for _ in &mut x {}
|
|
|
|
let r = &x;
|
|
for _ in r {}
|
|
}
|