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
use crate::array::iterator::local_iterator::*;
#[derive(Clone, Debug)]
pub struct Enumerate<I> {
iter: I,
cur_index: usize,
}
impl<I> Enumerate<I>
where
I: IndexedLocalIterator,
{
pub(crate) fn new(iter: I, cur_index: usize) -> Enumerate<I> {
Enumerate { iter, cur_index }
}
}
impl<I> LocalIterator for Enumerate<I>
where
I: IndexedLocalIterator,
{
type Item = (usize, <I as LocalIterator>::Item);
type Array = <I as LocalIterator>::Array;
fn init(&self, start_i: usize, cnt: usize) -> Enumerate<I> {
let val = Enumerate::new(self.iter.init(start_i, cnt), start_i);
val
}
fn array(&self) -> Self::Array {
self.iter.array()
}
fn next(&mut self) -> Option<Self::Item> {
if let Some(a) = self.iter.next() {
let i = self.iterator_index(self.cur_index)?;
self.cur_index += 1;
Some((i, a))
} else {
None
}
}
fn elems(&self, in_elems: usize) -> usize {
let in_elems = self.iter.elems(in_elems);
in_elems
}
fn advance_index(&mut self, count: usize) {
self.iter.advance_index(count);
self.cur_index += count;
}
}
impl<I> IndexedLocalIterator for Enumerate<I>
where
I: IndexedLocalIterator,
{
fn iterator_index(&self, index: usize) -> Option<usize> {
let i_index = self.iter.iterator_index(index);
i_index
}
}