769aa0a7b3
Part of #18469 [breaking-change] A receiver will only ever get a single auto-reference. Previously arrays and strings would get two, e.g., [T] would be auto-ref'ed to &&[T]. This is usually apparent when a trait is implemented for `&[T]` and has a method takes self by reference. The usual solution is to implement the trait for `[T]` (the DST form).
57 lines
1.7 KiB
Rust
57 lines
1.7 KiB
Rust
// Copyright 2012-4 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.
|
|
|
|
// Tests that type assignability is used to search for instances when
|
|
// making method calls, but only if there aren't any matches without
|
|
// it.
|
|
|
|
#![feature(unboxed_closures)]
|
|
|
|
trait iterable<A> {
|
|
fn iterate<F>(&self, blk: F) -> bool where F: FnMut(&A) -> bool;
|
|
}
|
|
|
|
impl<'a,A> iterable<A> for &'a [A] {
|
|
fn iterate<F>(&self, f: F) -> bool where F: FnMut(&A) -> bool {
|
|
self.iter().all(f)
|
|
}
|
|
}
|
|
|
|
impl<A> iterable<A> for Vec<A> {
|
|
fn iterate<F>(&self, f: F) -> bool where F: FnMut(&A) -> bool {
|
|
self.iter().all(f)
|
|
}
|
|
}
|
|
|
|
fn length<A, T: iterable<A>>(x: T) -> uint {
|
|
let mut len = 0;
|
|
x.iterate(|_y| {
|
|
len += 1;
|
|
true
|
|
});
|
|
return len;
|
|
}
|
|
|
|
pub fn main() {
|
|
let x: Vec<int> = vec!(0,1,2,3);
|
|
// Call a method
|
|
x.iterate(|y| { assert!(x[*y as uint] == *y); true });
|
|
// Call a parameterized function
|
|
assert_eq!(length(x.clone()), x.len());
|
|
// Call a parameterized function, with type arguments that require
|
|
// a borrow
|
|
assert_eq!(length::<int, &[int]>(x.as_slice()), x.len());
|
|
|
|
// Now try it with a type that *needs* to be borrowed
|
|
let z = [0,1,2,3];
|
|
// Call a parameterized function
|
|
assert_eq!(length::<int, &[int]>(&z), z.len());
|
|
}
|