Skip to main content

FilteredEngineData

Struct FilteredEngineData 

Source
pub struct FilteredEngineData { /* private fields */ }
Expand description

Engine data paired with a selection vector indicating which rows are logically selected.

A value of true in the selection vector means the corresponding row is selected (i.e., not deleted), while false means the row is logically deleted and should be ignored. If the selection vector is shorter than the number of rows in data then all rows not covered by the selection vector are assumed to be selected.

Interpreting unselected (false) rows will result in incorrect/undefined behavior.

Implementations§

Source§

impl FilteredEngineData

Source

pub fn try_new( data: Box<dyn EngineData>, selection_vector: Vec<bool>, ) -> DeltaResult<Self>

Source

pub fn data(&self) -> &dyn EngineData

Returns a reference to the underlying engine data.

Source

pub fn selection_vector(&self) -> &[bool]

Returns a reference to the selection vector.

Source

pub fn into_parts(self) -> (Box<dyn EngineData>, Vec<bool>)

Consumes the FilteredEngineData and returns the underlying data and selection vector.

Source

pub fn with_all_rows_selected(data: Box<dyn EngineData>) -> Self

Creates a new FilteredEngineData with all rows selected.

This is a convenience method for the common case where you want to wrap EngineData in FilteredEngineData without any filtering.

Source

pub fn apply_selection_vector(self) -> DeltaResult<Box<dyn EngineData>>

Apply the contained selection vector and return an engine data with only the selected rows included. This consumes the FilteredEngineData.

Trait Implementations§

Source§

impl From<Box<dyn EngineData>> for FilteredEngineData

Source§

fn from(data: Box<dyn EngineData>) -> Self

Converts EngineData into FilteredEngineData with all rows selected.

This is a convenience conversion that wraps the provided engine data in a FilteredEngineData with an empty selection vector, meaning all rows are logically selected.

§Example
let engine_data: Box<dyn EngineData> = ...;
let filtered: FilteredEngineData = engine_data.into();
Source§

impl HasSelectionVector for FilteredEngineData

Source§

fn has_selected_rows(&self) -> bool

Available on crate feature internal-api only.

Returns true if any row in the selection vector is marked as selected

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> AsAny for T
where T: Any + Send + Sync,

Source§

fn any_ref(&self) -> &(dyn Any + Send + Sync + 'static)

Obtains a dyn Any reference to the object: Read more
Source§

fn as_any(self: Arc<T>) -> Arc<dyn Any + Send + Sync>

Obtains an Arc<dyn Any> reference to the object: Read more
Source§

fn into_any(self: Box<T>) -> Box<dyn Any + Send + Sync>

Converts the object to Box<dyn Any>: Read more
Source§

fn type_name(&self) -> &'static str

Convenient wrapper for std::any::type_name, since Any does not provide it and Any::type_id is useless as a debugging aid (its Debug is just a mess of hex digits).
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> 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> 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> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Sized + 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
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Sized + 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.
Source§

impl<KernelType, ArrowType> TryIntoArrow<ArrowType> for KernelType
where ArrowType: TryFromKernel<KernelType>,

Source§

fn try_into_arrow(self) -> Result<ArrowType, ArrowError>

Available on crate feature arrow-conversion and (crate features arrow-conversion or declarative-plans or default-engine-base) only.
Source§

impl<KernelType, ArrowType> TryIntoKernel<KernelType> for ArrowType
where KernelType: TryFromArrow<ArrowType>,

Source§

fn try_into_kernel(self) -> Result<KernelType, ArrowError>

Available on crate feature arrow-conversion and (crate features arrow-conversion or declarative-plans or default-engine-base) only.
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