orx-concurrent-iter 3.3.0

A thread-safe and ergonomic concurrent iterator trait and efficient lock-free implementations.
Documentation
use super::{con_iter::ConIterJaggedOwned, slice_iter::RawJaggedSliceIterOwned};
use crate::{ChunkPuller, implementations::jagged_arrays::indexer::JaggedIndexer};

pub struct ChunkPullerJaggedOwned<'i, T, X>
where
    T: Send,
    X: JaggedIndexer,
{
    con_iter: &'i ConIterJaggedOwned<T, X>,
    chunk_size: usize,
}

impl<'i, T, X> ChunkPullerJaggedOwned<'i, T, X>
where
    T: Send,
    X: JaggedIndexer,
{
    pub(super) fn new(con_iter: &'i ConIterJaggedOwned<T, X>, chunk_size: usize) -> Self {
        Self {
            con_iter,
            chunk_size,
        }
    }
}

impl<T, X> ChunkPuller for ChunkPullerJaggedOwned<'_, T, X>
where
    T: Send,
    X: JaggedIndexer,
{
    type ChunkItem = T;

    type Chunk<'c>
        = RawJaggedSliceIterOwned<'c, T>
    where
        Self: 'c;

    fn chunk_size(&self) -> usize {
        self.chunk_size
    }

    fn pull(&mut self) -> Option<Self::Chunk<'_>> {
        self.con_iter
            .progress_and_get_iter(self.chunk_size)
            .map(|(_begin_idx, iter)| iter)
    }

    fn pull_with_idx(&mut self) -> Option<(usize, Self::Chunk<'_>)> {
        self.con_iter.progress_and_get_iter(self.chunk_size)
    }
}