Skip to main content

VecMerger

pub struct VecMerger<D, T, R> { /* private fields */ }
Expand description

A Merger implementation for Vec<(D, T, R)> that drains owned inputs.

Trait Implementations§

Source§

impl<D, T, R> Default for VecMerger<D, T, R>

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl<D, T, R> Merger for VecMerger<D, T, R>
where D: Ord + Clone + 'static, T: Ord + Clone + PartialOrder + 'static, R: Semigroup + Clone + 'static,

Source§

type Chunk = Vec<(D, T, R)>

The internal representation of chunks of data.
Source§

type Time = T

The type of time in frontiers to extract updates.
Source§

fn merge( &mut self, list1: Vec<Vec<(D, T, R)>>, list2: Vec<Vec<(D, T, R)>>, output: &mut Vec<Vec<(D, T, R)>>, stash: &mut Vec<Vec<(D, T, R)>>, )

Merge chains into an output chain.
Source§

fn extract( &mut self, merged: Vec<Vec<(D, T, R)>>, upper: AntichainRef<'_, T>, frontier: &mut Antichain<T>, ship: &mut Vec<Vec<(D, T, R)>>, kept: &mut Vec<Vec<(D, T, R)>>, stash: &mut Vec<Vec<(D, T, R)>>, )

Extract ready updates based on the upper frontier.
Source§

fn account(chunk: &Vec<(D, T, R)>) -> (usize, usize, usize, usize)

Account size and allocation changes. Returns a tuple of (records, size, capacity, allocations).

Auto Trait Implementations§

§

impl<D, T, R> Freeze for VecMerger<D, T, R>

§

impl<D, T, R> RefUnwindSafe for VecMerger<D, T, R>

§

impl<D, T, R> Send for VecMerger<D, T, R>
where D: Send, T: Send, R: Send,

§

impl<D, T, R> Sync for VecMerger<D, T, R>
where D: Sync, T: Sync, R: Sync,

§

impl<D, T, R> Unpin for VecMerger<D, T, R>
where D: Unpin, T: Unpin, R: Unpin,

§

impl<D, T, R> UnsafeUnpin for VecMerger<D, T, R>

§

impl<D, T, R> UnwindSafe for VecMerger<D, T, R>
where D: UnwindSafe, T: UnwindSafe, R: 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<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<'a, S, T> Semigroup<&'a S> for T
where T: Semigroup<S>,

Source§

fn plus_equals(&mut self, rhs: &&'a S)

The method of std::ops::AddAssign, for types that do not implement AddAssign.
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.