ValueBuilder

Struct ValueBuilder 

Source
pub struct ValueBuilder(Vec<u8>);
Expand description

Wrapper around a Vec<u8> that provides methods for appending primitive values, variant types, and metadata.

This is used internally by the builders to construct the the value field for Variant values.

You can reuse an existing Vec<u8> by using the from impl

Tuple Fields§

§0: Vec<u8>

Implementations§

Source§

impl ValueBuilder

Source

pub fn new() -> Self

Construct a ValueBuffer that will write to a new underlying Vec

Source§

impl ValueBuilder

Source

fn append_u8(&mut self, term: u8)

Source

fn append_slice(&mut self, other: &[u8])

Source

fn append_primitive_header(&mut self, primitive_type: VariantPrimitiveType)

Source

pub fn into_inner(self) -> Vec<u8>

Returns the underlying buffer, consuming self

Source

fn inner_mut(&mut self) -> &mut Vec<u8>

Source

fn append_null(&mut self)

Source

fn append_bool(&mut self, value: bool)

Source

fn append_int8(&mut self, value: i8)

Source

fn append_int16(&mut self, value: i16)

Source

fn append_int32(&mut self, value: i32)

Source

fn append_int64(&mut self, value: i64)

Source

fn append_float(&mut self, value: f32)

Source

fn append_double(&mut self, value: f64)

Source

fn append_date(&mut self, value: NaiveDate)

Source

fn append_timestamp_micros(&mut self, value: DateTime<Utc>)

Source

fn append_timestamp_ntz_micros(&mut self, value: NaiveDateTime)

Source

fn append_time_micros(&mut self, value: NaiveTime)

Source

fn append_timestamp_nanos(&mut self, value: DateTime<Utc>)

Source

fn append_timestamp_ntz_nanos(&mut self, value: NaiveDateTime)

Source

fn append_uuid(&mut self, value: Uuid)

Source

fn append_decimal4(&mut self, decimal4: VariantDecimal4)

Source

fn append_decimal8(&mut self, decimal8: VariantDecimal8)

Source

fn append_decimal16(&mut self, decimal16: VariantDecimal16)

Source

fn append_binary(&mut self, value: &[u8])

Source

fn append_short_string(&mut self, value: ShortString<'_>)

Source

fn append_string(&mut self, value: &str)

Source

fn append_object(state: ParentState<'_>, obj: VariantObject<'_, '_>)

Source

fn try_append_object( state: ParentState<'_>, obj: VariantObject<'_, '_>, ) -> Result<(), ArrowError>

Source

fn append_list(state: ParentState<'_>, list: VariantList<'_, '_>)

Source

fn try_append_list( state: ParentState<'_>, list: VariantList<'_, '_>, ) -> Result<(), ArrowError>

Source

pub fn offset(&self) -> usize

Returns the current size of the underlying buffer

Source

pub fn append_variant(state: ParentState<'_>, variant: Variant<'_, '_>)

Appends a variant to the builder.

§Panics

This method will panic if the variant contains duplicate field names in objects when validation is enabled. For a fallible version, use ValueBuilder::try_append_variant

Source

pub fn try_append_variant( state: ParentState<'_>, variant: Variant<'_, '_>, ) -> Result<(), ArrowError>

Tries to append a variant to the provided ParentState instance.

The attempt fails if the variant contains duplicate field names in objects when validation is enabled.

Source

pub fn append_variant_bytes(state: ParentState<'_>, variant: Variant<'_, '_>)

Appends a variant to the buffer by copying raw bytes when possible.

For objects and lists, this directly copies their underlying byte representation instead of performing a logical copy and without touching the metadata builder. For other variant types, this falls back to the standard append behavior.

The caller must ensure that the metadata dictionary is already built and correct for any objects or lists being appended.

Source

fn append_header_start_from_buf_pos( &mut self, start_pos: usize, header_byte: u8, is_large: bool, num_fields: usize, ) -> usize

Writes out the header byte for a variant object or list, from the starting position of the builder, will return the position after this write

Source

fn append_offset_array_start_from_buf_pos( &mut self, start_pos: usize, offsets: impl IntoIterator<Item = usize>, data_size: Option<usize>, nbytes: u8, ) -> usize

Writes out the offsets for an array of offsets, including the final offset (data size). from the starting position of the buffer, will return the position after this write

Trait Implementations§

Source§

impl Debug for ValueBuilder

Source§

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

Formats the value using the given formatter. Read more
Source§

impl Default for ValueBuilder

Source§

fn default() -> ValueBuilder

Returns the “default value” for a type. 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.

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, 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.