2011-08-30 16:23:20 -07:00
|
|
|
// In this case, the code should compile and should
|
|
|
|
// succeed at runtime
|
2012-09-11 17:46:20 -07:00
|
|
|
extern mod std;
|
2012-09-05 12:32:05 -07:00
|
|
|
use vec::{head, is_not_empty, last, same_length, zip};
|
2011-08-30 16:23:20 -07:00
|
|
|
|
2012-06-29 16:26:56 -07:00
|
|
|
fn enum_chars(start: u8, end: u8) -> ~[char] {
|
2012-03-10 17:07:23 -08:00
|
|
|
assert start < end;
|
|
|
|
let mut i = start;
|
2012-06-29 16:26:56 -07:00
|
|
|
let mut r = ~[];
|
2012-09-26 17:33:34 -07:00
|
|
|
while i <= end { r.push(i as char); i += 1u as u8; }
|
2012-08-01 17:30:05 -07:00
|
|
|
return r;
|
2012-03-10 17:07:23 -08:00
|
|
|
}
|
|
|
|
|
2012-06-29 16:26:56 -07:00
|
|
|
fn enum_uints(start: uint, end: uint) -> ~[uint] {
|
2012-03-10 17:07:23 -08:00
|
|
|
assert start < end;
|
|
|
|
let mut i = start;
|
2012-06-29 16:26:56 -07:00
|
|
|
let mut r = ~[];
|
2012-09-26 17:33:34 -07:00
|
|
|
while i <= end { r.push(i); i += 1u; }
|
2012-08-01 17:30:05 -07:00
|
|
|
return r;
|
2012-03-10 17:07:23 -08:00
|
|
|
}
|
|
|
|
|
2011-08-30 16:23:20 -07:00
|
|
|
fn main() {
|
|
|
|
let a = 'a' as u8, j = 'j' as u8, k = 1u, l = 10u;
|
|
|
|
let chars = enum_chars(a, j);
|
2011-09-02 15:34:58 -07:00
|
|
|
let ints = enum_uints(k, l);
|
2011-08-30 16:23:20 -07:00
|
|
|
|
|
|
|
let ps = zip(chars, ints);
|
|
|
|
|
|
|
|
assert (head(ps) == ('a', 1u));
|
2012-03-08 15:24:27 -08:00
|
|
|
assert (last(ps) == (j as char, 10u));
|
2011-08-30 17:19:13 -07:00
|
|
|
}
|