rust/src/test/run-pass/class-impl-very-parameterized-trait.rs

124 lines
2.7 KiB
Rust
Raw Normal View History

// xfail-fast
#[legacy_modes];
extern mod std;
2012-09-05 12:32:05 -07:00
use std::map::*;
enum cat_type { tuxedo, tabby, tortoiseshell }
2012-08-27 16:26:35 -07:00
impl cat_type : cmp::Eq {
pure fn eq(&&other: cat_type) -> bool {
(self as uint) == (other as uint)
}
pure fn ne(&&other: cat_type) -> bool { !self.eq(other) }
2012-08-27 16:26:35 -07:00
}
// Very silly -- this just returns the value of the name field
// for any int value that's less than the meows field
// ok: T should be in scope when resolving the trait ref for map
struct cat<T: Copy> {
// Yes, you can have negative meows
priv mut meows : int,
2012-09-06 19:40:15 -07:00
mut how_hungry : int,
name : T,
}
impl<T: Copy> cat<T> {
fn speak() { self.meow(); }
fn eat() -> bool {
if self.how_hungry > 0 {
2012-08-22 17:24:52 -07:00
error!("OM NOM NOM");
self.how_hungry -= 2;
2012-08-01 17:30:05 -07:00
return true;
}
else {
2012-08-22 17:24:52 -07:00
error!("Not hungry!");
2012-08-01 17:30:05 -07:00
return false;
}
}
}
2012-09-10 15:38:28 -07:00
impl<T: Copy> cat<T> : Map<int, T> {
2012-08-27 16:26:35 -07:00
pure fn size() -> uint { self.meows as uint }
fn insert(+k: int, +_v: T) -> bool {
self.meows += k;
true
}
fn contains_key(+k: int) -> bool { k <= self.meows }
fn contains_key_ref(k: &int) -> bool { self.contains_key(*k) }
2012-08-06 12:34:08 -07:00
fn get(+k:int) -> T { match self.find(k) {
2012-08-20 12:23:37 -07:00
Some(v) => { v }
None => { fail ~"epic fail"; }
}
}
2012-08-27 16:26:35 -07:00
pure fn find(+k:int) -> Option<T> { if k <= self.meows {
2012-08-20 12:23:37 -07:00
Some(self.name)
}
2012-08-20 12:23:37 -07:00
else { None }
}
2012-08-21 17:02:40 -07:00
fn remove(+k:int) -> bool {
2012-08-06 12:34:08 -07:00
match self.find(k) {
2012-08-20 12:23:37 -07:00
Some(x) => {
2012-08-21 17:02:40 -07:00
self.meows -= k; true
}
2012-08-20 12:23:37 -07:00
None => { false }
}
}
2012-08-27 16:26:35 -07:00
pure fn each(f: fn(+int, +T) -> bool) {
let mut n = int::abs(self.meows);
while n > 0 {
if !f(n, self.name) { break; }
n -= 1;
}
}
2012-08-27 16:26:35 -07:00
pure fn each_key(&&f: fn(+int) -> bool) {
for self.each |k, _v| { if !f(k) { break; } loop;};
}
2012-08-27 16:26:35 -07:00
pure fn each_value(&&f: fn(+T) -> bool) {
for self.each |_k, v| { if !f(v) { break; } loop;};
}
2012-08-27 16:26:35 -07:00
pure fn each_ref(f: fn(k: &int, v: &T) -> bool) {}
pure fn each_key_ref(f: fn(k: &int) -> bool) {}
pure fn each_value_ref(f: fn(k: &T) -> bool) {}
fn clear() { }
}
priv impl<T: Copy> cat<T> {
fn meow() {
self.meows += 1;
error!("Meow %d", self.meows);
if self.meows % 5 == 0 {
self.how_hungry += 1;
}
}
}
fn cat<T: Copy>(in_x : int, in_y : int, in_name: T) -> cat<T> {
2012-09-05 15:58:43 -07:00
cat {
meows: in_x,
how_hungry: in_y,
name: in_name
}
}
fn main() {
let nyan : cat<~str> = cat(0, 2, ~"nyan");
2012-06-30 16:19:07 -07:00
for uint::range(1u, 5u) |_i| { nyan.speak(); }
2012-08-20 12:23:37 -07:00
assert(nyan.find(1) == Some(~"nyan"));
assert(nyan.find(10) == None);
let spotty : cat<cat_type> = cat(2, 57, tuxedo);
2012-06-30 16:19:07 -07:00
for uint::range(0u, 6u) |_i| { spotty.speak(); }
assert(spotty.size() == 8u);
assert(spotty.contains_key(2));
assert(spotty.get(3) == tuxedo);
}