-// Copyright 2012 The Rust Project Developers. See the COPYRIGHT
+// Copyright 2012-2014 The Rust Project Developers. See the COPYRIGHT
// file at the top-level directory of this distribution and at
// http://rust-lang.org/COPYRIGHT.
//
// option. This file may not be copied, modified, or distributed
// except according to those terms.
-// xfail-fast
use std::cmp;
-use std::container::{Container, Mutable, Map};
-use std::int;
-use std::uint;
+#[derive(Copy, Clone, Debug)]
enum cat_type { tuxedo, tabby, tortoiseshell }
-impl cmp::Eq for cat_type {
+impl cmp::PartialEq for cat_type {
fn eq(&self, other: &cat_type) -> bool {
- ((*self) as uint) == ((*other) as uint)
+ ((*self) as usize) == ((*other) as usize)
}
fn ne(&self, other: &cat_type) -> bool { !(*self).eq(other) }
}
// Very silly -- this just returns the value of the name field
-// for any int value that's less than the meows field
+// for any isize value that's less than the meows field
// ok: T should be in scope when resolving the trait ref for map
struct cat<T> {
// Yes, you can have negative meows
- priv meows : int,
+ meows : isize,
- how_hungry : int,
+ how_hungry : isize,
name : T,
}
pub fn eat(&mut self) -> bool {
if self.how_hungry > 0 {
- error!("OM NOM NOM");
+ println!("OM NOM NOM");
self.how_hungry -= 2;
return true;
} else {
- error!("Not hungry!");
+ println!("Not hungry!");
return false;
}
}
-}
-
-impl<T> Container for cat<T> {
- fn len(&const self) -> uint { self.meows as uint }
- fn is_empty(&const self) -> bool { self.meows == 0 }
-}
-
-impl<T> Mutable for cat<T> {
+ fn len(&self) -> usize { self.meows as usize }
+ fn is_empty(&self) -> bool { self.meows == 0 }
fn clear(&mut self) {}
-}
-
-impl<T> Map<int, T> for cat<T> {
- fn contains_key(&self, k: &int) -> bool { *k <= self.meows }
+ fn contains_key(&self, k: &isize) -> bool { *k <= self.meows }
- fn insert(&mut self, k: int, _: T) -> bool {
- self.meows += k;
- true
- }
-
- fn find<'a>(&'a self, k: &int) -> Option<&'a T> {
+ fn find(&self, k: &isize) -> Option<&T> {
if *k <= self.meows {
Some(&self.name)
} else {
None
}
}
+ fn insert(&mut self, k: isize, _: T) -> bool {
+ self.meows += k;
+ true
+ }
- fn find_mut<'a>(&'a mut self, _k: &int) -> Option<&'a mut T> { fail!() }
+ fn find_mut(&mut self, _k: &isize) -> Option<&mut T> { panic!() }
- fn remove(&mut self, k: &int) -> bool {
+ fn remove(&mut self, k: &isize) -> bool {
if self.find(k).is_some() {
self.meows -= *k; true
} else {
}
}
- fn pop(&mut self, _k: &int) -> Option<T> { fail!() }
+ fn pop(&mut self, _k: &isize) -> Option<T> { panic!() }
- fn swap(&mut self, _k: int, _v: T) -> Option<T> { fail!() }
+ fn swap(&mut self, _k: isize, _v: T) -> Option<T> { panic!() }
}
impl<T> cat<T> {
- pub fn get<'a>(&'a self, k: &int) -> &'a T {
+ pub fn get(&self, k: &isize) -> &T {
match self.find(k) {
Some(v) => { v }
- None => { fail!("epic fail"); }
+ None => { panic!("epic fail"); }
}
}
- pub fn new(in_x: int, in_y: int, in_name: T) -> cat<T> {
+ pub fn new(in_x: isize, in_y: isize, in_name: T) -> cat<T> {
cat{meows: in_x, how_hungry: in_y, name: in_name }
}
}
impl<T> cat<T> {
fn meow(&mut self) {
self.meows += 1;
- error!("Meow %d", self.meows);
+ println!("Meow {}", self.meows);
if self.meows % 5 == 0 {
self.how_hungry += 1;
}
}
pub fn main() {
- let mut nyan: cat<~str> = cat::new(0, 2, ~"nyan");
- for uint::range(1, 5) |_| { nyan.speak(); }
- assert!(*nyan.find(&1).unwrap() == ~"nyan");
+ let mut nyan: cat<String> = cat::new(0, 2, "nyan".to_string());
+ for _ in 1_usize..5 { nyan.speak(); }
+ assert_eq!(*nyan.find(&1).unwrap(), "nyan".to_string());
assert_eq!(nyan.find(&10), None);
- let mut spotty: cat<cat_type> = cat::new(2, 57, tuxedo);
- for uint::range(0, 6) |_| { spotty.speak(); }
+ let mut spotty: cat<cat_type> = cat::new(2, 57, cat_type::tuxedo);
+ for _ in 0_usize..6 { spotty.speak(); }
assert_eq!(spotty.len(), 8);
assert!((spotty.contains_key(&2)));
- assert_eq!(spotty.get(&3), &tuxedo);
+ assert_eq!(spotty.get(&3), &cat_type::tuxedo);
}