2015-08-15 18:55:25 +02:00
|
|
|
#![feature(step_by)]
|
2016-04-26 13:31:52 +02:00
|
|
|
#![feature(inclusive_range_syntax)]
|
2015-08-15 18:55:25 +02:00
|
|
|
#![feature(plugin)]
|
|
|
|
#![plugin(clippy)]
|
|
|
|
|
|
|
|
struct NotARange;
|
|
|
|
impl NotARange {
|
|
|
|
fn step_by(&self, _: u32) {}
|
|
|
|
}
|
|
|
|
|
2015-11-03 15:42:52 +01:00
|
|
|
#[deny(range_step_by_zero, range_zip_with_len)]
|
2015-08-15 18:55:25 +02:00
|
|
|
fn main() {
|
|
|
|
(0..1).step_by(0); //~ERROR Range::step_by(0) produces an infinite iterator
|
|
|
|
// No warning for non-zero step
|
|
|
|
(0..1).step_by(1);
|
|
|
|
|
|
|
|
(1..).step_by(0); //~ERROR Range::step_by(0) produces an infinite iterator
|
2016-04-26 13:31:52 +02:00
|
|
|
(1...2).step_by(0); //~ERROR Range::step_by(0) produces an infinite iterator
|
2015-08-15 18:55:25 +02:00
|
|
|
|
|
|
|
let x = 0..1;
|
|
|
|
x.step_by(0); //~ERROR Range::step_by(0) produces an infinite iterator
|
|
|
|
|
|
|
|
// No error, not a range.
|
|
|
|
let y = NotARange;
|
|
|
|
y.step_by(0);
|
2015-11-03 15:42:52 +01:00
|
|
|
|
2015-12-13 06:35:35 +01:00
|
|
|
let v1 = vec![1,2,3];
|
|
|
|
let v2 = vec![4,5];
|
|
|
|
let _x = v1.iter().zip(0..v1.len()); //~ERROR It is more idiomatic to use v1.iter().enumerate()
|
|
|
|
let _y = v1.iter().zip(0..v2.len()); // No error
|
2015-08-15 18:55:25 +02:00
|
|
|
}
|