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
use super::*;
use take_mut::take;
impl<I: Iterator> ListFn for &mut I {
type Item = I::Item;
type End = Self;
fn list(self) -> List<Self> {
match self.next() {
Option::None => List::End(self),
Option::Some(first) => List::Some(first, self),
}
}
}
pub struct ListIterator<S: ListFn<End = S>>(S);
impl<S: ListFn<End = S>> Iterator for ListIterator<S> {
type Item = S::Item;
fn next(&mut self) -> Option<Self::Item> {
let mut result = None;
take(&mut self.0, |list| match list.list() {
List::End(end) => end,
List::Some(first, next) => {
result = Some(first);
next
}
});
result
}
}
pub trait IterEx: ListFn<End = Self> {
fn iter(self) -> ListIterator<Self> {
ListIterator(self)
}
}
impl<S: ListFn<End = Self>> IterEx for S {}