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
extern crate through;
use through::*;
use std::collections::VecDeque;
use std::fmt::{Debug, Formatter};
use std::fmt;
pub struct SmallQueue<T> {
state: SmallQueueState<T>
}
impl<T> SmallQueue<T> {
pub fn new() -> Self {
SmallQueue {
state: SmallQueueState::Zero
}
}
pub fn of(elem: T) -> Self {
SmallQueue {
state: SmallQueueState::One(elem)
}
}
pub fn add(&mut self, elem: T) {
through(&mut self.state, move |state| match state {
SmallQueueState::Zero => SmallQueueState::One(elem),
SmallQueueState::One(present) => {
let mut queue = VecDeque::new();
queue.push_back(present);
queue.push_back(elem);
SmallQueueState::Several(queue)
},
SmallQueueState::Several(mut queue) => {
queue.push_back(elem);
SmallQueueState::Several(queue)
}
})
}
pub fn remove(&mut self) -> Option<T> {
through_and(&mut self.state, |state| match state {
SmallQueueState::Zero => (SmallQueueState::Zero, None),
SmallQueueState::One(elem) => (SmallQueueState::Zero, Some(elem)),
SmallQueueState::Several(mut queue) => {
let elem = queue.pop_front();
if queue.len() == 1 {
(SmallQueueState::One(queue.pop_front().unwrap()), elem)
} else {
(SmallQueueState::Several(queue), elem)
}
}
})
}
pub fn is_empty(&self) -> bool {
match &self.state {
&SmallQueueState::Zero => true,
_ => false,
}
}
}
enum SmallQueueState<T> {
Zero,
One(T),
Several(VecDeque<T>)
}
impl<T: Debug> Debug for SmallQueue<T> {
fn fmt(&self, f: &mut Formatter) -> Result<(), fmt::Error> {
match self.state {
SmallQueueState::Zero => f.write_str("[]"),
SmallQueueState::One(ref elem) => {
f.write_str("[")?;
elem.fmt(f)?;
f.write_str("]")
},
SmallQueueState::Several(ref queue) => queue.fmt(f),
}
}
}