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
use crate::query::view;
use rayon::{
iter,
iter::IndexedParallelIterator,
};
pub trait ParResults {
type View: Send;
type Iterator: IndexedParallelIterator<Item = Self::View>;
fn into_parallel_iterator(self) -> Self::Iterator;
}
impl ParResults for iter::RepeatN<view::Null> {
type View = view::Null;
type Iterator = Self;
fn into_parallel_iterator(self) -> Self::Iterator {
self
}
}
impl<C, I, R> ParResults for (I, R)
where
C: Send,
I: IndexedParallelIterator<Item = C>,
R: ParResults,
{
type View = (C, R::View);
type Iterator = iter::Zip<I, R::Iterator>;
fn into_parallel_iterator(self) -> Self::Iterator {
self.0.zip(self.1.into_parallel_iterator())
}
}