RecordBatchStore

Struct RecordBatchStore 

Source
struct RecordBatchStore {
    next_id: u32,
    batches: HashMap<u32, RecordBatchEntry>,
    batches_size: usize,
}
Expand description

This structure tracks [RecordBatch] by an id so that:

  1. The baches can be tracked via an id that can be copied cheaply
  2. The total memory held by all batches is tracked

Fields§

§next_id: u32

id generator

§batches: HashMap<u32, RecordBatchEntry>

storage

§batches_size: usize

total size of all record batches tracked by this store

Implementations§

Source§

impl RecordBatchStore

Source

fn new() -> Self

Source

pub fn register(&mut self, batch: RecordBatch) -> RecordBatchEntry

Register this batch with the store and assign an ID. No attempt is made to compare this batch to other batches

Source

pub fn insert(&mut self, entry: RecordBatchEntry)

Insert a record batch entry into this store, tracking its memory use, if it has any uses

Source

fn clear(&mut self)

Clear all values in this store, invalidating all previous batch ids

Source

fn get(&self, id: u32) -> Option<&RecordBatchEntry>

Source

fn len(&self) -> usize

returns the total number of batches stored in this store

Source

fn unused_rows(&self) -> usize

Returns the total number of rows in batches minus the number which are in use

Source

fn is_empty(&self) -> bool

returns true if the store has nothing stored

Source

pub fn unuse(&mut self, id: u32)

remove a use from the specified batch id. If the use count reaches zero the batch entry is removed from the store

panics if there were no remaining uses of id

Source

pub fn size(&self) -> usize

returns the size of memory used by this store, including all referenced RecordBatches, in bytes

Trait Implementations§

Source§

impl Debug for RecordBatchStore

Source§

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

Formats the value using the given formatter. Read more

Auto Trait Implementations§

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.

§

impl<T> Instrument for T

§

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

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

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

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

§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns [Action::Follow] only if self and other return Action::Follow. Read more
§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns [Action::Follow] if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

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

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

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

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
§

fn with_current_subscriber(self) -> WithDispatch<Self>

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

impl<T> ErasedDestructor for T
where T: 'static,