2013-09-14 12:37:45 -05:00
|
|
|
// Copyright 2013 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.
|
|
|
|
|
2014-02-19 21:29:58 -06:00
|
|
|
extern crate collections;
|
|
|
|
|
2013-09-14 12:37:45 -05:00
|
|
|
use std::clone::{Clone, DeepClone};
|
|
|
|
use std::cmp::{TotalEq, Ord, TotalOrd, Equiv};
|
|
|
|
use std::cmp::Equal;
|
|
|
|
use std::container::{Container, Map, MutableMap};
|
|
|
|
use std::default::Default;
|
2014-02-07 18:36:59 -06:00
|
|
|
use std::str::{Str, SendStr, Owned, Slice};
|
2013-09-14 12:37:45 -05:00
|
|
|
use std::to_str::ToStr;
|
2014-02-19 21:29:58 -06:00
|
|
|
use collections::HashMap;
|
2013-09-14 12:37:45 -05:00
|
|
|
use std::option::Some;
|
|
|
|
|
2013-09-25 02:43:37 -05:00
|
|
|
pub fn main() {
|
2013-09-14 12:37:45 -05:00
|
|
|
let mut map: HashMap<SendStr, uint> = HashMap::new();
|
2014-02-07 18:36:59 -06:00
|
|
|
assert!(map.insert(Slice("foo"), 42));
|
|
|
|
assert!(!map.insert(Owned(~"foo"), 42));
|
|
|
|
assert!(!map.insert(Slice("foo"), 42));
|
|
|
|
assert!(!map.insert(Owned(~"foo"), 42));
|
2013-09-14 12:37:45 -05:00
|
|
|
|
2014-02-07 18:36:59 -06:00
|
|
|
assert!(!map.insert(Slice("foo"), 43));
|
|
|
|
assert!(!map.insert(Owned(~"foo"), 44));
|
|
|
|
assert!(!map.insert(Slice("foo"), 45));
|
|
|
|
assert!(!map.insert(Owned(~"foo"), 46));
|
2013-09-14 12:37:45 -05:00
|
|
|
|
|
|
|
let v = 46;
|
|
|
|
|
2014-02-07 18:36:59 -06:00
|
|
|
assert_eq!(map.find(&Owned(~"foo")), Some(&v));
|
|
|
|
assert_eq!(map.find(&Slice("foo")), Some(&v));
|
2013-09-14 12:37:45 -05:00
|
|
|
|
|
|
|
let (a, b, c, d) = (50, 51, 52, 53);
|
|
|
|
|
2014-02-07 18:36:59 -06:00
|
|
|
assert!(map.insert(Slice("abc"), a));
|
|
|
|
assert!(map.insert(Owned(~"bcd"), b));
|
|
|
|
assert!(map.insert(Slice("cde"), c));
|
|
|
|
assert!(map.insert(Owned(~"def"), d));
|
2013-09-14 12:37:45 -05:00
|
|
|
|
2014-02-07 18:36:59 -06:00
|
|
|
assert!(!map.insert(Slice("abc"), a));
|
|
|
|
assert!(!map.insert(Owned(~"bcd"), b));
|
|
|
|
assert!(!map.insert(Slice("cde"), c));
|
|
|
|
assert!(!map.insert(Owned(~"def"), d));
|
2013-09-14 12:37:45 -05:00
|
|
|
|
2014-02-07 18:36:59 -06:00
|
|
|
assert!(!map.insert(Owned(~"abc"), a));
|
|
|
|
assert!(!map.insert(Slice("bcd"), b));
|
|
|
|
assert!(!map.insert(Owned(~"cde"), c));
|
|
|
|
assert!(!map.insert(Slice("def"), d));
|
2013-09-14 12:37:45 -05:00
|
|
|
|
|
|
|
assert_eq!(map.find_equiv(&("abc")), Some(&a));
|
|
|
|
assert_eq!(map.find_equiv(&("bcd")), Some(&b));
|
|
|
|
assert_eq!(map.find_equiv(&("cde")), Some(&c));
|
|
|
|
assert_eq!(map.find_equiv(&("def")), Some(&d));
|
|
|
|
|
|
|
|
assert_eq!(map.find_equiv(&(~"abc")), Some(&a));
|
|
|
|
assert_eq!(map.find_equiv(&(~"bcd")), Some(&b));
|
|
|
|
assert_eq!(map.find_equiv(&(~"cde")), Some(&c));
|
|
|
|
assert_eq!(map.find_equiv(&(~"def")), Some(&d));
|
|
|
|
|
2014-02-07 18:36:59 -06:00
|
|
|
assert_eq!(map.find_equiv(&Slice("abc")), Some(&a));
|
|
|
|
assert_eq!(map.find_equiv(&Slice("bcd")), Some(&b));
|
|
|
|
assert_eq!(map.find_equiv(&Slice("cde")), Some(&c));
|
|
|
|
assert_eq!(map.find_equiv(&Slice("def")), Some(&d));
|
2013-09-14 12:37:45 -05:00
|
|
|
|
2014-02-07 18:36:59 -06:00
|
|
|
assert_eq!(map.find_equiv(&Owned(~"abc")), Some(&a));
|
|
|
|
assert_eq!(map.find_equiv(&Owned(~"bcd")), Some(&b));
|
|
|
|
assert_eq!(map.find_equiv(&Owned(~"cde")), Some(&c));
|
|
|
|
assert_eq!(map.find_equiv(&Owned(~"def")), Some(&d));
|
2013-09-14 12:37:45 -05:00
|
|
|
}
|