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
use super::noop::*; use super::plumbing::*; use super::ParallelIterator; pub(super) fn for_each<I, F, T>(pi: I, op: &F) where I: ParallelIterator<Item = T>, F: Fn(T) + Sync, T: Send, { let consumer = ForEachConsumer { op }; pi.drive_unindexed(consumer) } struct ForEachConsumer<'f, F> { op: &'f F, } impl<'f, F, T> Consumer<T> for ForEachConsumer<'f, F> where F: Fn(T) + Sync, { type Folder = ForEachConsumer<'f, F>; type Reducer = NoopReducer; type Result = (); fn split_at(self, _index: usize) -> (Self, Self, NoopReducer) { (self.split_off_left(), self, NoopReducer) } fn into_folder(self) -> Self { self } fn full(&self) -> bool { false } } impl<'f, F, T> Folder<T> for ForEachConsumer<'f, F> where F: Fn(T) + Sync, { type Result = (); fn consume(self, item: T) -> Self { (self.op)(item); self } fn consume_iter<I>(self, iter: I) -> Self where I: IntoIterator<Item = T>, { iter.into_iter().for_each(self.op); self } fn complete(self) {} fn full(&self) -> bool { false } } impl<'f, F, T> UnindexedConsumer<T> for ForEachConsumer<'f, F> where F: Fn(T) + Sync, { fn split_off_left(&self) -> Self { ForEachConsumer { op: self.op } } fn to_reducer(&self) -> NoopReducer { NoopReducer } }