2012-07-06 17:50:50 -05:00
|
|
|
// Tests that type assignability is used to search for instances when
|
|
|
|
// making method calls, but only if there aren't any matches without
|
|
|
|
// it.
|
|
|
|
|
2012-07-31 12:27:51 -05:00
|
|
|
trait iterable<A> {
|
2012-09-18 23:41:37 -05:00
|
|
|
fn iterate(blk: fn(x: &A) -> bool);
|
2012-07-06 17:50:50 -05:00
|
|
|
}
|
|
|
|
|
2012-08-07 20:10:06 -05:00
|
|
|
impl<A> &[A]: iterable<A> {
|
2012-09-18 23:41:37 -05:00
|
|
|
fn iterate(f: fn(x: &A) -> bool) {
|
|
|
|
for vec::each(self) |e| {
|
|
|
|
if !f(e) { break; }
|
|
|
|
}
|
2012-07-06 17:50:50 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-08-07 20:10:06 -05:00
|
|
|
impl<A> ~[A]: iterable<A> {
|
2012-09-18 23:41:37 -05:00
|
|
|
fn iterate(f: fn(x: &A) -> bool) {
|
|
|
|
for vec::each(self) |e| {
|
|
|
|
if !f(e) { break; }
|
|
|
|
}
|
2012-07-06 17:50:50 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn length<A, T: iterable<A>>(x: T) -> uint {
|
|
|
|
let mut len = 0;
|
|
|
|
for x.iterate() |_y| { len += 1 }
|
2012-08-01 19:30:05 -05:00
|
|
|
return len;
|
2012-07-06 17:50:50 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let x = ~[0,1,2,3];
|
|
|
|
// Call a method
|
2012-09-18 23:41:37 -05:00
|
|
|
for x.iterate() |y| { assert x[*y] == *y; }
|
2012-07-06 17:50:50 -05:00
|
|
|
// Call a parameterized function
|
|
|
|
assert length(x) == vec::len(x);
|
|
|
|
// Call a parameterized function, with type arguments that require
|
|
|
|
// a borrow
|
|
|
|
assert length::<int, &[int]>(x) == vec::len(x);
|
|
|
|
|
|
|
|
// Now try it with a type that *needs* to be borrowed
|
2012-10-09 23:28:04 -05:00
|
|
|
let z = [0,1,2,3];
|
2012-07-06 17:50:50 -05:00
|
|
|
// Call a method
|
2012-09-18 23:41:37 -05:00
|
|
|
for z.iterate() |y| { assert z[*y] == *y; }
|
2012-07-06 17:50:50 -05:00
|
|
|
// Call a parameterized function
|
|
|
|
assert length::<int, &[int]>(z) == vec::len(z);
|
|
|
|
}
|