DynProjection

Struct DynProjection 

Source
pub struct DynProjection(/* private fields */);
Expand description

Column projection descriptor used to derive projected dynamic views.

Implementations§

Source§

impl DynProjection

Source

pub fn from_indices<I>( schema: &Schema, indices: I, ) -> Result<Self, DynViewError>
where I: IntoIterator<Item = usize>,

Create a projection from explicit column indices.

§Errors

Returns DynViewError::ColumnOutOfBounds if any index exceeds the schema width.

Source

pub fn from_schema( source: &Schema, projection: &Schema, ) -> Result<Self, DynViewError>

Create a projection by matching a projected schema against the source schema.

Fields are matched by name; data type and nullability must also align.

§Errors

Returns DynViewError when a projected field is missing from the source schema or when its metadata disagrees.

Source

pub fn fields(&self) -> &Fields

Projected schema fields in order.

Source

pub fn len(&self) -> usize

Number of projected columns.

Source

pub fn is_empty(&self) -> bool

Returns true when the projection contains zero columns.

Source

pub fn to_parquet_mask(&self) -> ParquetProjectionMask

Returns the Parquet projection mask corresponding to this projection.

Source

pub fn project_row_view<'a>( &self, schema: &'a DynSchema, batch: &'a RecordBatch, row: usize, ) -> Result<DynRowView<'a>, DynViewError>

Project a single row from batch using this projection, returning a borrowed view.

§Errors

Returns DynViewError when schema validation fails, the row index is out of bounds, or the projection width mismatches the batch.

Source

pub fn project_row_raw( &self, schema: &DynSchema, batch: &RecordBatch, row: usize, ) -> Result<DynRowRaw, DynViewError>

Project a single row from batch and capture it as lifetime-erased raw cells.

Trait Implementations§

Source§

impl Clone for DynProjection

Source§

fn clone(&self) -> DynProjection

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for DynProjection

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. 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> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
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<T> Allocation for T
where T: RefUnwindSafe + Send + Sync,