mirror of
https://github.com/rust-lang/rust-clippy
synced 2025-01-04 17:28:46 +00:00
119 lines
2.7 KiB
Rust
119 lines
2.7 KiB
Rust
#![warn(clippy::needless_range_loop)]
|
|
#![allow(clippy::useless_vec)]
|
|
//@no-rustfix
|
|
fn calc_idx(i: usize) -> usize {
|
|
(i + i + 20) % 4
|
|
}
|
|
|
|
fn main() {
|
|
let ns = vec![2, 3, 5, 7];
|
|
|
|
for i in 3..10 {
|
|
//~^ ERROR: the loop variable `i` is only used to index `ns`
|
|
//~| NOTE: `-D clippy::needless-range-loop` implied by `-D warnings`
|
|
println!("{}", ns[i]);
|
|
}
|
|
|
|
for i in 3..10 {
|
|
println!("{}", ns[i % 4]);
|
|
}
|
|
|
|
for i in 3..10 {
|
|
println!("{}", ns[i % ns.len()]);
|
|
}
|
|
|
|
for i in 3..10 {
|
|
println!("{}", ns[calc_idx(i)]);
|
|
}
|
|
|
|
for i in 3..10 {
|
|
println!("{}", ns[calc_idx(i) % 4]);
|
|
}
|
|
|
|
let mut ms = vec![1, 2, 3, 4, 5, 6];
|
|
for i in 0..ms.len() {
|
|
//~^ ERROR: the loop variable `i` is only used to index `ms`
|
|
ms[i] *= 2;
|
|
}
|
|
assert_eq!(ms, vec![2, 4, 6, 8, 10, 12]);
|
|
|
|
let mut ms = vec![1, 2, 3, 4, 5, 6];
|
|
for i in 0..ms.len() {
|
|
//~^ ERROR: the loop variable `i` is only used to index `ms`
|
|
let x = &mut ms[i];
|
|
*x *= 2;
|
|
}
|
|
assert_eq!(ms, vec![2, 4, 6, 8, 10, 12]);
|
|
|
|
let g = vec![1, 2, 3, 4, 5, 6];
|
|
let glen = g.len();
|
|
for i in 0..glen {
|
|
let x: u32 = g[i + 1..].iter().sum();
|
|
println!("{}", g[i] + x);
|
|
}
|
|
assert_eq!(g, vec![20, 18, 15, 11, 6, 0]);
|
|
|
|
let mut g = vec![1, 2, 3, 4, 5, 6];
|
|
let glen = g.len();
|
|
for i in 0..glen {
|
|
g[i] = g[i + 1..].iter().sum();
|
|
}
|
|
assert_eq!(g, vec![20, 18, 15, 11, 6, 0]);
|
|
|
|
let x = 5;
|
|
let mut vec = vec![0; 9];
|
|
|
|
for i in x..x + 4 {
|
|
//~^ ERROR: the loop variable `i` is only used to index `vec`
|
|
vec[i] += 1;
|
|
}
|
|
|
|
let x = 5;
|
|
let mut vec = vec![0; 10];
|
|
|
|
for i in x..=x + 4 {
|
|
//~^ ERROR: the loop variable `i` is only used to index `vec`
|
|
vec[i] += 1;
|
|
}
|
|
|
|
let arr = [1, 2, 3];
|
|
|
|
for i in 0..3 {
|
|
//~^ ERROR: the loop variable `i` is only used to index `arr`
|
|
println!("{}", arr[i]);
|
|
}
|
|
|
|
for i in 0..2 {
|
|
//~^ ERROR: the loop variable `i` is only used to index `arr`
|
|
println!("{}", arr[i]);
|
|
}
|
|
|
|
for i in 1..3 {
|
|
//~^ ERROR: the loop variable `i` is only used to index `arr`
|
|
println!("{}", arr[i]);
|
|
}
|
|
|
|
// Fix #5945
|
|
let mut vec = vec![1, 2, 3, 4];
|
|
for i in 0..vec.len() - 1 {
|
|
vec[i] += 1;
|
|
}
|
|
let mut vec = vec![1, 2, 3, 4];
|
|
for i in vec.len() - 3..vec.len() {
|
|
vec[i] += 1;
|
|
}
|
|
let mut vec = vec![1, 2, 3, 4];
|
|
for i in vec.len() - 3..vec.len() - 1 {
|
|
vec[i] += 1;
|
|
}
|
|
}
|
|
|
|
mod issue2277 {
|
|
pub fn example(list: &[[f64; 3]]) {
|
|
let mut x: [f64; 3] = [10.; 3];
|
|
|
|
for i in 0..3 {
|
|
x[i] = list.iter().map(|item| item[i]).sum::<f64>();
|
|
}
|
|
}
|
|
}
|