rust/tests/ui/range.rs

39 lines
773 B
Rust
Raw Normal View History

struct NotARange;
impl NotARange {
fn step_by(&self, _: u32) {}
}
2018-07-28 17:34:52 +02:00
#[warn(clippy::iterator_step_by_zero, clippy::range_zip_with_len)]
fn main() {
2017-07-05 14:51:33 +08:00
let _ = (0..1).step_by(0);
// No warning for non-zero step
let _ = (0..1).step_by(1);
2017-07-05 14:51:33 +08:00
let _ = (1..).step_by(0);
2017-09-28 10:40:19 -07:00
let _ = (1..=2).step_by(0);
2017-07-05 14:51:33 +08:00
let x = 0..1;
let _ = x.step_by(0);
// No error, not a range.
let y = NotARange;
y.step_by(0);
2018-12-09 23:26:16 +01:00
let v1 = vec![1, 2, 3];
let v2 = vec![4, 5];
2017-02-08 14:58:07 +01:00
let _x = v1.iter().zip(0..v1.len());
let _y = v1.iter().zip(0..v2.len()); // No error
2017-07-05 14:51:33 +08:00
// check const eval
2018-12-09 23:26:16 +01:00
let _ = v1.iter().step_by(2 / 3);
}
2017-10-12 23:24:21 +09:00
#[allow(unused)]
fn no_panic_with_fake_range_types() {
struct Range {
foo: i32,
}
let _ = Range { foo: 0 };
}