Struct rayon::iter::collect::consumer::CollectResult

source ·
pub(super) struct CollectResult<'c, T> {
    start: SendPtr<T>,
    total_len: usize,
    initialized_len: usize,
    invariant_lifetime: PhantomData<&'c mut &'c mut [T]>,
}
Expand description

CollectResult represents an initialized part of the target slice.

This is a proxy owner of the elements in the slice; when it drops, the elements will be dropped, unless its ownership is released before then.

Fields§

§start: SendPtr<T>

This pointer and length has the same representation as a slice, but retains the provenance of the entire array so that we can merge these regions together in CollectReducer.

§total_len: usize§initialized_len: usize

The current initialized length after start

§invariant_lifetime: PhantomData<&'c mut &'c mut [T]>

Lifetime invariance guarantees that the data flows from consumer to result, especially for the scope_fn callback in Collect::with_consumer.

Implementations§

source§

impl<'c, T> CollectResult<'c, T>

source

pub(super) fn len(&self) -> usize

The current length of the collect result

source

pub(super) fn release_ownership(self) -> usize

Release ownership of the slice of elements, and return the length

Trait Implementations§

source§

impl<'c, T> Drop for CollectResult<'c, T>

source§

fn drop(&mut self)

Executes the destructor for this type. Read more
source§

impl<'c, T: Send + 'c> Folder<T> for CollectResult<'c, T>

§

type Result = CollectResult<'c, T>

The type of result that will ultimately be produced by the folder.
source§

fn consume(self, item: T) -> Self

Consume next item and return new sequential state.
source§

fn complete(self) -> Self::Result

Finish consuming items, produce final result.
source§

fn full(&self) -> bool

Hint whether this Folder would like to stop processing further items, e.g. if a search has been completed.
source§

fn consume_iter<I>(self, iter: I) -> Self
where I: IntoIterator<Item = Item>,

Consume items from the iterator until full, and return new sequential state. Read more
source§

impl<'c, T> Reducer<CollectResult<'c, T>> for CollectReducer

source§

fn reduce( self, left: CollectResult<'c, T>, right: CollectResult<'c, T>, ) -> CollectResult<'c, T>

Reduce two final results into one; this is executed after a split.
source§

impl<'c, T> Send for CollectResult<'c, T>
where T: Send,

Auto Trait Implementations§

§

impl<'c, T> Freeze for CollectResult<'c, T>

§

impl<'c, T> RefUnwindSafe for CollectResult<'c, T>
where T: RefUnwindSafe,

§

impl<'c, T> Sync for CollectResult<'c, T>
where T: Send + Sync,

§

impl<'c, T> Unpin for CollectResult<'c, T>

§

impl<'c, T> !UnwindSafe for CollectResult<'c, T>

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<T> IntoEither for T

source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
source§

impl<T> Pointable for T

source§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

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

§

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>,

§

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.