1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
use std::cmp::{ PartialEq, Eq, Ord, PartialOrd, Ordering };
use std::iter::{Iterator, IntoIterator, FromIterator};
use tree::binary_tree::{BinaryTree, Iter};
#[derive(Clone)]
pub struct Entry<K: Eq + Ord, V> {
key: K,
val: V,
}
impl<K: Ord + Eq, V> PartialEq for Entry<K, V> {
fn eq(&self, other: &Self) -> bool { self.key == other.key }
fn ne(&self, other: &Self) -> bool { self.key != other.key }
}
impl<K: Ord + Eq, V> PartialEq<K> for Entry<K, V> {
fn eq(&self, other: &K) -> bool { self.key == *other }
fn ne(&self, other: &K) -> bool { self.key != *other }
}
impl<K: Ord + Eq, V> Eq for Entry<K, V> {}
impl<K: Ord + Eq, V> PartialOrd for Entry<K, V> {
fn partial_cmp(&self, other: &Self) -> Option<Ordering> { self.key.partial_cmp(&other.key) }
fn lt(&self, other: &Self) -> bool { self.key < other.key }
fn le(&self, other: &Self) -> bool { self.key <= other.key }
fn gt(&self, other: &Self) -> bool { self.key > other.key }
fn ge(&self, other: &Self) -> bool { self.key >= other.key }
}
impl<K: Ord + Eq, V> PartialOrd<K> for Entry<K, V> {
fn partial_cmp(&self, other: &K) -> Option<Ordering> { self.key.partial_cmp(other) }
fn lt(&self, other: &K) -> bool { self.key < *other }
fn le(&self, other: &K) -> bool { self.key <= *other }
fn gt(&self, other: &K) -> bool { self.key > *other }
fn ge(&self, other: &K) -> bool { self.key >= *other }
}
impl<K: Eq + Ord, V> Entry<K, V> {
pub fn new(key: K, val: V) -> Self {
Entry {
key: key,
val: val
}
}
}
impl<K: Ord + Eq, V> Ord for Entry<K, V> {
fn cmp(&self, other: &Self) -> Ordering { self.key.cmp(&other.key) }
}
pub struct Map<K: Clone + Ord + Eq, V: Clone> {
tree: BinaryTree<Entry<K, V>>,
}
impl<K: Clone + Ord + Eq, V: Clone> Map<K, V> {
pub fn new() -> Self {
Map {
tree: BinaryTree::empty()
}
}
pub fn get(&self, key: K) -> Option<Entry<K, V>> {
self.tree.get(key)
}
pub fn put(self, key: K, val: V) -> Self {
Map { tree: self.tree.insert(Entry::new(key, val)) }
}
}
impl<K: Clone + Ord + Eq, V: Clone> IntoIterator for Map<K, V> {
type Item = Entry<K, V>;
type IntoIter = Iter<Entry<K, V>>;
#[inline]
fn into_iter(self) -> Self::IntoIter {
self.tree.into_iter()
}
}
impl<K: Clone + Ord + Eq, V: Clone> FromIterator<Entry<K, V>> for Map<K, V> {
fn from_iter<I: IntoIterator<Item=Entry<K, V>>>(iterator: I) -> Self {
iterator
.into_iter()
.fold(Map::new(), | map, Entry{key, val} | map.put(key, val))
}
}
impl<K: Clone + Ord + Eq, V: Clone> FromIterator<(K, V)> for Map<K, V> {
fn from_iter<I: IntoIterator<Item=(K, V)>>(iterator: I) -> Self {
iterator
.into_iter()
.fold(Map::new(), | map, (k, v) | map.put(k, v))
}
}
#[test]
fn map_macro() {
assert!(true);
}