ValueBuilder

Struct ValueBuilder 

Source
pub struct ValueBuilder(/* private fields */);
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

Implementations§

Source§

impl ValueBuilder

Source

pub fn new() -> Self

Construct a ValueBuffer that will write to a new underlying Vec

Source§

impl ValueBuilder

Source

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

Returns the underlying buffer, consuming self

Source

pub fn offset(&self) -> usize

Returns the current size of the underlying buffer

Source

pub fn append_variant<S: BuilderSpecificState>( state: ParentState<'_, S>, 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<S: BuilderSpecificState>( state: ParentState<'_, S>, 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<S: BuilderSpecificState>( state: ParentState<'_, S>, 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.

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.