futures_concurrency::concurrent_stream

Struct Enumerate

source
pub struct Enumerate<CS: ConcurrentStream> { /* private fields */ }
Expand description

A concurrent iterator that yields the current count and the element during iteration.

This struct is created by the enumerate method on ConcurrentStream. See its documentation for more.

Trait Implementations§

source§

impl<CS: ConcurrentStream> ConcurrentStream for Enumerate<CS>

source§

type Item = (usize, <CS as ConcurrentStream>::Item)

Which item will we be yielding?
source§

type Future = EnumerateFuture<<CS as ConcurrentStream>::Future, <CS as ConcurrentStream>::Item>

What’s the type of the future containing our items?
source§

async fn drive<C>(self, consumer: C) -> C::Output
where C: Consumer<Self::Item, Self::Future>,

Internal method used to define the behavior of this concurrent iterator. You should not need to call this directly. This method causes the iterator self to start producing items and to feed them to the consumer consumer one by one.
source§

fn concurrency_limit(&self) -> Option<NonZeroUsize>

How much concurrency should we apply?
source§

fn size_hint(&self) -> (usize, Option<usize>)

How many items could we potentially end up returning?
source§

fn enumerate(self) -> Enumerate<Self>
where Self: Sized,

Creates a stream which gives the current iteration count as well as the next value. Read more
source§

fn limit(self, limit: Option<NonZeroUsize>) -> Limit<Self>
where Self: Sized,

Obtain a simple pass-through adapter.
source§

fn take(self, limit: usize) -> Take<Self>
where Self: Sized,

Creates a stream that yields the first n elements, or fewer if the underlying iterator ends sooner.
source§

fn map<F, FutB, B>( self, f: F, ) -> Map<Self, F, Self::Future, Self::Item, FutB, B>
where Self: Sized, F: Fn(Self::Item) -> FutB + Clone, FutB: Future<Output = B>,

Convert items from one type into another
source§

async fn for_each<F, Fut>(self, f: F)
where Self: Sized, F: Fn(Self::Item) -> Fut + Clone, Fut: Future<Output = ()>,

Iterate over each item concurrently
source§

async fn try_for_each<F, Fut, E>(self, f: F) -> Result<(), E>
where Self: Sized, F: Fn(Self::Item) -> Fut + Clone, Fut: Future<Output = Result<(), E>>,

Iterate over each item concurrently, short-circuit on error. Read more
source§

async fn collect<B>(self) -> B
where B: FromConcurrentStream<Self::Item>, Self: Sized,

Transforms an iterator into a collection.
source§

impl<CS: Debug + ConcurrentStream> Debug for Enumerate<CS>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<CS> Freeze for Enumerate<CS>
where CS: Freeze,

§

impl<CS> RefUnwindSafe for Enumerate<CS>
where CS: RefUnwindSafe,

§

impl<CS> Send for Enumerate<CS>
where CS: Send,

§

impl<CS> Sync for Enumerate<CS>
where CS: Sync,

§

impl<CS> Unpin for Enumerate<CS>
where CS: Unpin,

§

impl<CS> UnwindSafe for Enumerate<CS>
where CS: UnwindSafe,

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<S> IntoConcurrentStream for S

source§

type Item = <S as ConcurrentStream>::Item

The type of the elements being iterated over.
source§

type IntoConcurrentStream = S

Which kind of iterator are we turning this into?
source§

fn into_co_stream(self) -> <S as IntoConcurrentStream>::IntoConcurrentStream

Convert self into a concurrent iterator.
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

source§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.