use super::plumbing::*; use super::*; use std::cmp::min; /// `Take` is an iterator that iterates over the first `n` elements. /// This struct is created by the [`take()`] method on [`IndexedParallelIterator`] /// /// [`take()`]: trait.IndexedParallelIterator.html#method.take /// [`IndexedParallelIterator`]: trait.IndexedParallelIterator.html #[must_use = "iterator adaptors are lazy and do nothing unless consumed"] #[derive(Debug, Clone)] pub struct Take { base: I, n: usize, } impl Take where I: IndexedParallelIterator, { /// Creates a new `Take` iterator. pub(super) fn new(base: I, n: usize) -> Self { let n = min(base.len(), n); Take { base, n } } } impl ParallelIterator for Take where I: IndexedParallelIterator, { type Item = I::Item; fn drive_unindexed(self, consumer: C) -> C::Result where C: UnindexedConsumer, { bridge(self, consumer) } fn opt_len(&self) -> Option { Some(self.len()) } } impl IndexedParallelIterator for Take where I: IndexedParallelIterator, { fn len(&self) -> usize { self.n } fn drive>(self, consumer: C) -> C::Result { bridge(self, consumer) } fn with_producer(self, callback: CB) -> CB::Output where CB: ProducerCallback, { return self.base.with_producer(Callback { callback, n: self.n, }); struct Callback { callback: CB, n: usize, } impl ProducerCallback for Callback where CB: ProducerCallback, { type Output = CB::Output; fn callback

(self, base: P) -> CB::Output where P: Producer, { let (producer, _) = base.split_at(self.n); self.callback.callback(producer) } } } }