Struct mz_timely_util::buffer::ConsolidateBuffer

source ·
pub struct ConsolidateBuffer<'a, 'b, T, D, R: Semigroup, P>
where P: Push<Bundle<T, Vec<(D, T, R)>>> + 'a, T: Data + Timestamp + 'a, D: 'a + Data,
{ /* private fields */ }
Expand description

A buffer that consolidates updates

The buffer implements a wrapper around OutputHandle consolidating elements pushed to it. It is backed by a capacity-limited buffer, which means that compaction only occurs within the dimensions of the buffer, i.e. the number of unique keys is less than half of the buffer’s capacity.

A cap is retained whenever the current time changes to be able to flush on drop or when the time changes again.

The buffer is filled with updates until it reaches its capacity. At this point, the updates are consolidated to free up space. This process repeats until the consolidation recovered less than half of the buffer’s capacity, at which point the buffer will be shipped.

The buffer retains a capability to send data on flush. It will flush all data once dropped, if time changes, or if the buffer capacity is reached.

Implementations§

source§

impl<'a, 'b, T, D: Data, R: Semigroup, P> ConsolidateBuffer<'a, 'b, T, D, R, P>
where T: Data + Timestamp + 'a, P: Push<Bundle<T, Vec<(D, T, R)>>> + 'a,

source

pub fn new( output_handle: &'b mut OutputHandle<'a, T, (D, T, R), P>, port: usize ) -> Self

Create a new ConsolidateBuffer, wrapping the provided session.

  • output_handle: The output to send data to.
  • ‘port’: The output port to retain capabilities for.
source

pub fn give_iterator<I: Iterator<Item = (D, T, R)>>( &mut self, cap: &InputCapability<T>, iter: I )

Provides an iterator of elements to the buffer

source

pub fn give(&mut self, cap: &InputCapability<T>, data: (D, T, R))

Give an element to the buffer

source

pub fn give_at(&mut self, cap: &Capability<T>, data: (D, T, R))

Give an element to the buffer, using a pre-fabricated capability. Note that the capability must be valid for the associated output.

source

pub fn flush(&mut self)

Flush the internal buffer to the underlying session

Trait Implementations§

source§

impl<'a, 'b, T, D, R: Semigroup, P> Drop for ConsolidateBuffer<'a, 'b, T, D, R, P>
where P: Push<Bundle<T, Vec<(D, T, R)>>> + 'a, T: Data + Timestamp + 'a, D: 'a + Data,

source§

fn drop(&mut self)

Executes the destructor for this type. Read more

Auto Trait Implementations§

§

impl<'a, 'b, T, D, R, P> Freeze for ConsolidateBuffer<'a, 'b, T, D, R, P>
where T: Freeze,

§

impl<'a, 'b, T, D, R, P> !RefUnwindSafe for ConsolidateBuffer<'a, 'b, T, D, R, P>

§

impl<'a, 'b, T, D, R, P> !Send for ConsolidateBuffer<'a, 'b, T, D, R, P>

§

impl<'a, 'b, T, D, R, P> !Sync for ConsolidateBuffer<'a, 'b, T, D, R, P>

§

impl<'a, 'b, T, D, R, P> Unpin for ConsolidateBuffer<'a, 'b, T, D, R, P>
where T: Unpin, D: Unpin, R: Unpin,

§

impl<'a, 'b, T, D, R, P> !UnwindSafe for ConsolidateBuffer<'a, 'b, T, D, R, P>

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, U> CastInto<U> for T
where U: CastFrom<T>,

source§

fn cast_into(self) -> U

Performs the cast.
source§

impl<R, O, T> CopyOnto<ConsecutiveOffsetPairs<R, O>> for T
where R: Region<Index = (usize, usize)>, O: OffsetContainer<usize>, T: CopyOnto<R>,

source§

fn copy_onto( self, target: &mut ConsecutiveOffsetPairs<R, O> ) -> <ConsecutiveOffsetPairs<R, O> as Region>::Index

Copy self into the target container, returning an index that allows to look up the corresponding read item.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> FutureExt for T

source§

fn with_context(self, otel_cx: Context) -> WithContext<Self>

Attaches the provided Context to this type, returning a WithContext wrapper. Read more
source§

fn with_current_context(self) -> WithContext<Self>

Attaches the current Context to this type, returning a WithContext wrapper. Read more
source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> IntoRequest<T> for T

source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
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<R, T> PushInto<FlatStack<R>> for T
where R: Region + Clone + 'static, T: CopyOnto<R>,

source§

fn push_into(self, target: &mut FlatStack<R>)

Push self into the target container.
source§

impl<T> PushInto<Vec<T>> for T

source§

fn push_into(self, target: &mut Vec<T>)

Push self into the target container.
source§

impl<T> Same for T

§

type Output = T

Should always be Self
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.
source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

source§

fn vzip(self) -> V

source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more