test inclusive ranges
Mostly copy the tests from half-open ranges, adding some more for DoubleEndedIterator and ExactSizeIterator. Also thoroughly (I think) test that the feature gates are working.
This commit is contained in:
parent
37a4cb3212
commit
69719df611
21
src/test/compile-fail/range_inclusive_gate.rs
Normal file
21
src/test/compile-fail/range_inclusive_gate.rs
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
// Copyright 2016 The Rust Project Developers. See the COPYRIGHT
|
||||||
|
// file at the top-level directory of this distribution and at
|
||||||
|
// http://rust-lang.org/COPYRIGHT.
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
||||||
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
||||||
|
// option. This file may not be copied, modified, or distributed
|
||||||
|
// except according to those terms.
|
||||||
|
|
||||||
|
// Make sure that #![feature(inclusive_range)] is required.
|
||||||
|
|
||||||
|
#![feature(inclusive_range_syntax)]
|
||||||
|
// #![feature(inclusive_range)]
|
||||||
|
|
||||||
|
pub fn main() {
|
||||||
|
let _: std::ops::RangeInclusive<_> = 1...10;
|
||||||
|
//~^ ERROR use of unstable library feature 'inclusive_range'
|
||||||
|
}
|
||||||
|
|
||||||
|
|
18
src/test/parse-fail/range_inclusive.rs
Normal file
18
src/test/parse-fail/range_inclusive.rs
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
// Copyright 2016 The Rust Project Developers. See the COPYRIGHT
|
||||||
|
// file at the top-level directory of this distribution and at
|
||||||
|
// http://rust-lang.org/COPYRIGHT.
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
||||||
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
||||||
|
// option. This file may not be copied, modified, or distributed
|
||||||
|
// except according to those terms.
|
||||||
|
|
||||||
|
// Make sure that inclusive ranges with no end point don't parse.
|
||||||
|
|
||||||
|
#![feature(inclusive_range_syntax, inclusive_range)]
|
||||||
|
|
||||||
|
pub fn main() {
|
||||||
|
for _ in 1... {}
|
||||||
|
} //~ ERROR expected one of
|
||||||
|
|
74
src/test/parse-fail/range_inclusive_gate.rs
Normal file
74
src/test/parse-fail/range_inclusive_gate.rs
Normal file
@ -0,0 +1,74 @@
|
|||||||
|
// Copyright 2016 The Rust Project Developers. See the COPYRIGHT
|
||||||
|
// file at the top-level directory of this distribution and at
|
||||||
|
// http://rust-lang.org/COPYRIGHT.
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
||||||
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
||||||
|
// option. This file may not be copied, modified, or distributed
|
||||||
|
// except according to those terms.
|
||||||
|
|
||||||
|
// Make sure that #![feature(inclusive_range_syntax)] is required.
|
||||||
|
|
||||||
|
// #![feature(inclusive_range_syntax, inclusive_range)]
|
||||||
|
|
||||||
|
macro_rules! m {
|
||||||
|
() => { for _ in 1...10 {} } //~ ERROR inclusive range syntax is experimental
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(nope)]
|
||||||
|
fn f() {}
|
||||||
|
#[cfg(not(nope))]
|
||||||
|
fn f() {
|
||||||
|
for _ in 1...10 {} //~ ERROR inclusive range syntax is experimental
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(nope)]
|
||||||
|
macro_rules! n { () => {} }
|
||||||
|
#[cfg(not(nope))]
|
||||||
|
macro_rules! n {
|
||||||
|
() => { for _ in 1...10 {} } //~ ERROR inclusive range syntax is experimental
|
||||||
|
}
|
||||||
|
|
||||||
|
macro_rules! o {
|
||||||
|
() => {{
|
||||||
|
#[cfg(nope)]
|
||||||
|
fn g() {}
|
||||||
|
#[cfg(not(nope))]
|
||||||
|
fn g() {
|
||||||
|
for _ in 1...10 {} //~ ERROR inclusive range syntax is experimental
|
||||||
|
}
|
||||||
|
|
||||||
|
g();
|
||||||
|
}}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(nope)]
|
||||||
|
macro_rules! p { () => {} }
|
||||||
|
#[cfg(not(nope))]
|
||||||
|
macro_rules! p {
|
||||||
|
() => {{
|
||||||
|
#[cfg(nope)]
|
||||||
|
fn h() {}
|
||||||
|
#[cfg(not(nope))]
|
||||||
|
fn h() {
|
||||||
|
for _ in 1...10 {} //~ ERROR inclusive range syntax is experimental
|
||||||
|
}
|
||||||
|
|
||||||
|
h();
|
||||||
|
}}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn main() {
|
||||||
|
for _ in 1...10 {} //~ ERROR inclusive range syntax is experimental
|
||||||
|
for _ in ...10 {} //~ ERROR inclusive range syntax is experimental
|
||||||
|
|
||||||
|
f(); // not allowed in cfg'ed functions
|
||||||
|
|
||||||
|
m!(); // not allowed in macros
|
||||||
|
n!(); // not allowed in cfg'ed macros
|
||||||
|
o!(); // not allowed in macros that output cfgs
|
||||||
|
p!(); // not allowed in cfg'ed macros that output cfgs
|
||||||
|
}
|
||||||
|
|
||||||
|
|
100
src/test/run-pass/range_inclusive.rs
Normal file
100
src/test/run-pass/range_inclusive.rs
Normal file
@ -0,0 +1,100 @@
|
|||||||
|
// Copyright 2016 The Rust Project Developers. See the COPYRIGHT
|
||||||
|
// file at the top-level directory of this distribution and at
|
||||||
|
// http://rust-lang.org/COPYRIGHT.
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
||||||
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
||||||
|
// option. This file may not be copied, modified, or distributed
|
||||||
|
// except according to those terms.
|
||||||
|
|
||||||
|
// Test inclusive range syntax.
|
||||||
|
|
||||||
|
#![feature(inclusive_range_syntax, inclusive_range)]
|
||||||
|
|
||||||
|
use std::ops::{RangeInclusive, RangeToInclusive};
|
||||||
|
|
||||||
|
fn foo() -> isize { 42 }
|
||||||
|
|
||||||
|
// Test that range syntax works in return statements
|
||||||
|
fn return_range_to() -> RangeToInclusive<i32> { return ...1; }
|
||||||
|
|
||||||
|
pub fn main() {
|
||||||
|
let mut count = 0;
|
||||||
|
for i in 0_usize...10 {
|
||||||
|
assert!(i >= 0 && i <= 10);
|
||||||
|
count += i;
|
||||||
|
}
|
||||||
|
assert_eq!(count, 55);
|
||||||
|
|
||||||
|
let mut count = 0;
|
||||||
|
let mut range = 0_usize...10;
|
||||||
|
for i in range {
|
||||||
|
assert!(i >= 0 && i <= 10);
|
||||||
|
count += i;
|
||||||
|
}
|
||||||
|
assert_eq!(count, 55);
|
||||||
|
|
||||||
|
/* FIXME
|
||||||
|
let mut count = 0;
|
||||||
|
for i in (0_usize...10).step_by(2) {
|
||||||
|
assert!(i >= 0 && i <= 10 && i % 2 == 0);
|
||||||
|
count += i;
|
||||||
|
}
|
||||||
|
assert_eq!(count, 30);
|
||||||
|
*/
|
||||||
|
|
||||||
|
let _ = 0_usize...4+4-3;
|
||||||
|
let _ = 0...foo();
|
||||||
|
|
||||||
|
let _ = { &42...&100 }; // references to literals are OK
|
||||||
|
let _ = ...42_usize;
|
||||||
|
|
||||||
|
// Test we can use two different types with a common supertype.
|
||||||
|
let x = &42;
|
||||||
|
{
|
||||||
|
let y = 42;
|
||||||
|
let _ = x...&y;
|
||||||
|
}
|
||||||
|
|
||||||
|
// test the size hints and emptying
|
||||||
|
let mut long = 0...255u8;
|
||||||
|
let mut short = 42...42;
|
||||||
|
assert_eq!(long.size_hint(), (256, Some(256)));
|
||||||
|
assert_eq!(short.size_hint(), (1, Some(1)));
|
||||||
|
long.next();
|
||||||
|
short.next();
|
||||||
|
assert_eq!(long.size_hint(), (255, Some(255)));
|
||||||
|
assert_eq!(short.size_hint(), (0, Some(0)));
|
||||||
|
assert_eq!(short, RangeInclusive::Empty { at: 42 });
|
||||||
|
|
||||||
|
assert_eq!(long.len(), 255);
|
||||||
|
assert_eq!(short.len(), 0);
|
||||||
|
|
||||||
|
// test iterating backwards
|
||||||
|
assert_eq!(long.next_back(), Some(255));
|
||||||
|
assert_eq!(long.next_back(), Some(254));
|
||||||
|
assert_eq!(long.next_back(), Some(253));
|
||||||
|
assert_eq!(long.next(), Some(1));
|
||||||
|
assert_eq!(long.next(), Some(2));
|
||||||
|
assert_eq!(long.next_back(), Some(252));
|
||||||
|
for i in 3...251 {
|
||||||
|
assert_eq!(long.next(), Some(i));
|
||||||
|
}
|
||||||
|
assert_eq!(long, RangeInclusive::Empty { at: 251 });
|
||||||
|
|
||||||
|
// what happens if you have a nonsense range?
|
||||||
|
let mut nonsense = 10...5;
|
||||||
|
assert_eq!(nonsense.next(), None);
|
||||||
|
assert_eq!(nonsense, RangeInclusive::Empty { at: 10 });
|
||||||
|
|
||||||
|
// conversion
|
||||||
|
assert_eq!(0...9, (0..10).into());
|
||||||
|
assert_eq!(0...0, (0..1).into());
|
||||||
|
assert_eq!(RangeInclusive::Empty { at: 1 }, (1..0).into());
|
||||||
|
|
||||||
|
// output
|
||||||
|
assert_eq!(format!("{:?}", 0...10), "0...10");
|
||||||
|
assert_eq!(format!("{:?}", ...10), "...10");
|
||||||
|
assert_eq!(format!("{:?}", long), "[empty range @ 251]");
|
||||||
|
}
|
23
src/test/run-pass/range_inclusive_gate.rs
Normal file
23
src/test/run-pass/range_inclusive_gate.rs
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
// Copyright 2016 The Rust Project Developers. See the COPYRIGHT
|
||||||
|
// file at the top-level directory of this distribution and at
|
||||||
|
// http://rust-lang.org/COPYRIGHT.
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
||||||
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
||||||
|
// option. This file may not be copied, modified, or distributed
|
||||||
|
// except according to those terms.
|
||||||
|
|
||||||
|
// Test that you only need the syntax gate if you don't mention the structs.
|
||||||
|
|
||||||
|
#![feature(inclusive_range_syntax)]
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
let mut count = 0;
|
||||||
|
for i in 0_usize...10 {
|
||||||
|
assert!(i >= 0 && i <= 10);
|
||||||
|
count += i;
|
||||||
|
}
|
||||||
|
assert_eq!(count, 55);
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user