pub struct GenericListBuilder<OffsetSize, T>where
    OffsetSize: OffsetSizeTrait,
    T: ArrayBuilder,{ /* private fields */ }Expand description
Builder for GenericListArray
Use ListBuilder to build ListArrays and LargeListBuilder to build LargeListArrays.
§Example
Here is code that constructs a ListArray with the contents:
[[A,B,C], [], NULL, [D], [NULL, F]]
let values_builder = StringBuilder::new();
let mut builder = ListBuilder::new(values_builder);
// [A, B, C]
builder.values().append_value("A");
builder.values().append_value("B");
builder.values().append_value("C");
builder.append(true);
// [ ] (empty list)
builder.append(true);
// Null
builder.append(false);
// [D]
builder.values().append_value("D");
builder.append(true);
// [NULL, F]
builder.values().append_null();
builder.values().append_value("F");
builder.append(true);
// Build the array
let array = builder.finish();
// Values is a string array
// "A", "B" "C", "?", "D", NULL, "F"
assert_eq!(
  array.values().as_ref(),
  &StringArray::from(vec![
    Some("A"), Some("B"), Some("C"),
    Some("D"), None, Some("F")
  ])
);
// Offsets are indexes into the values array
assert_eq!(
  array.value_offsets(),
  &[0, 3, 3, 3, 4, 6]
);Implementations§
Source§impl<OffsetSize, T> GenericListBuilder<OffsetSize, T>where
    OffsetSize: OffsetSizeTrait,
    T: ArrayBuilder,
 
impl<OffsetSize, T> GenericListBuilder<OffsetSize, T>where
    OffsetSize: OffsetSizeTrait,
    T: ArrayBuilder,
Sourcepub fn new(values_builder: T) -> GenericListBuilder<OffsetSize, T>
 
pub fn new(values_builder: T) -> GenericListBuilder<OffsetSize, T>
Creates a new GenericListBuilder from a given values array builder
Sourcepub fn with_capacity(
    values_builder: T,
    capacity: usize,
) -> GenericListBuilder<OffsetSize, T>
 
pub fn with_capacity( values_builder: T, capacity: usize, ) -> GenericListBuilder<OffsetSize, T>
Creates a new GenericListBuilder from a given values array builder
capacity is the number of items to pre-allocate space for in this builder
Sourcepub fn with_field(
    self,
    field: impl Into<Arc<Field>>,
) -> GenericListBuilder<OffsetSize, T>
 
pub fn with_field( self, field: impl Into<Arc<Field>>, ) -> GenericListBuilder<OffsetSize, T>
Override the field passed to GenericListArray::new
By default a nullable field is created with the name item
Note: Self::finish and Self::finish_cloned will panic if the
field’s data type does not match that of T
Source§impl<OffsetSize, T> GenericListBuilder<OffsetSize, T>where
    OffsetSize: OffsetSizeTrait,
    T: ArrayBuilder + 'static,
 
impl<OffsetSize, T> GenericListBuilder<OffsetSize, T>where
    OffsetSize: OffsetSizeTrait,
    T: ArrayBuilder + 'static,
Sourcepub fn values(&mut self) -> &mut T
 
pub fn values(&mut self) -> &mut T
Returns the child array builder as a mutable reference.
This mutable reference can be used to append values into the child array builder,
but you must call append to delimit each distinct list value.
Sourcepub fn values_ref(&self) -> &T
 
pub fn values_ref(&self) -> &T
Returns the child array builder as an immutable reference
Sourcepub fn append(&mut self, is_valid: bool)
 
pub fn append(&mut self, is_valid: bool)
Finish the current variable-length list array slot
§Panics
Panics if the length of Self::values exceeds OffsetSize::MAX
Sourcepub fn append_value<I, V>(&mut self, i: I)
 
pub fn append_value<I, V>(&mut self, i: I)
Append a value to this GenericListBuilder
let mut builder = ListBuilder::new(Int32Builder::new());
builder.append_value([Some(1), Some(2), Some(3)]);
builder.append_value([]);
builder.append_value([None]);
let array = builder.finish();
assert_eq!(array.len(), 3);
assert_eq!(array.value_offsets(), &[0, 3, 3, 4]);
let values = array.values().as_primitive::<Int32Type>();
assert_eq!(values, &Int32Array::from(vec![Some(1), Some(2), Some(3), None]));This is an alternative API to appending directly to Self::values and
delimiting the result with Self::append
let mut builder = ListBuilder::new(Int32Builder::new());
builder.values().append_value(1);
builder.values().append_value(2);
builder.values().append_value(3);
builder.append(true);
builder.append(true);
builder.values().append_null();
builder.append(true);
let array = builder.finish();
assert_eq!(array.len(), 3);
assert_eq!(array.value_offsets(), &[0, 3, 3, 4]);
let values = array.values().as_primitive::<Int32Type>();
assert_eq!(values, &Int32Array::from(vec![Some(1), Some(2), Some(3), None]));Sourcepub fn append_null(&mut self)
 
pub fn append_null(&mut self)
Append a null to this GenericListBuilder
See Self::append_value for an example use.
Sourcepub fn append_nulls(&mut self, n: usize)
 
pub fn append_nulls(&mut self, n: usize)
Appends n nulls into the builder.
Sourcepub fn append_option<I, V>(&mut self, i: Option<I>)
 
pub fn append_option<I, V>(&mut self, i: Option<I>)
Appends an optional value into this GenericListBuilder
If Some calls Self::append_value otherwise calls Self::append_null
Sourcepub fn finish(&mut self) -> GenericListArray<OffsetSize>
 
pub fn finish(&mut self) -> GenericListArray<OffsetSize>
Builds the GenericListArray and reset this builder.
Sourcepub fn finish_cloned(&self) -> GenericListArray<OffsetSize>
 
pub fn finish_cloned(&self) -> GenericListArray<OffsetSize>
Builds the GenericListArray without resetting the builder.
Sourcepub fn offsets_slice(&self) -> &[OffsetSize]
 
pub fn offsets_slice(&self) -> &[OffsetSize]
Returns the current offsets buffer as a slice
Sourcepub fn validity_slice(&self) -> Option<&[u8]>
 
pub fn validity_slice(&self) -> Option<&[u8]>
Returns the current null buffer as a slice
Trait Implementations§
Source§impl<OffsetSize, T> ArrayBuilder for GenericListBuilder<OffsetSize, T>where
    OffsetSize: OffsetSizeTrait,
    T: ArrayBuilder + 'static,
 
impl<OffsetSize, T> ArrayBuilder for GenericListBuilder<OffsetSize, T>where
    OffsetSize: OffsetSizeTrait,
    T: ArrayBuilder + 'static,
Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
 
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Returns the builder as a mutable Any reference.
Source§fn into_box_any(self: Box<GenericListBuilder<OffsetSize, T>>) -> Box<dyn Any>
 
fn into_box_any(self: Box<GenericListBuilder<OffsetSize, T>>) -> Box<dyn Any>
Returns the boxed builder as a box of Any.
Source§fn finish_cloned(&self) -> Arc<dyn Array>
 
fn finish_cloned(&self) -> Arc<dyn Array>
Builds the array without resetting the builder.
Source§impl<OffsetSize, T> Debug for GenericListBuilder<OffsetSize, T>
 
impl<OffsetSize, T> Debug for GenericListBuilder<OffsetSize, T>
Source§impl<O, T> Default for GenericListBuilder<O, T>
 
impl<O, T> Default for GenericListBuilder<O, T>
Source§fn default() -> GenericListBuilder<O, T>
 
fn default() -> GenericListBuilder<O, T>
Source§impl<O, B, V, E> Extend<Option<V>> for GenericListBuilder<O, B>
 
impl<O, B, V, E> Extend<Option<V>> for GenericListBuilder<O, B>
Source§fn extend<T>(&mut self, iter: T)where
    T: IntoIterator<Item = Option<V>>,
 
fn extend<T>(&mut self, iter: T)where
    T: IntoIterator<Item = Option<V>>,
Source§fn extend_one(&mut self, item: A)
 
fn extend_one(&mut self, item: A)
extend_one)Source§fn extend_reserve(&mut self, additional: usize)
 
fn extend_reserve(&mut self, additional: usize)
extend_one)Auto Trait Implementations§
impl<OffsetSize, T> Freeze for GenericListBuilder<OffsetSize, T>where
    T: Freeze,
impl<OffsetSize, T> RefUnwindSafe for GenericListBuilder<OffsetSize, T>where
    T: RefUnwindSafe,
    OffsetSize: RefUnwindSafe,
impl<OffsetSize, T> Send for GenericListBuilder<OffsetSize, T>
impl<OffsetSize, T> Sync for GenericListBuilder<OffsetSize, T>
impl<OffsetSize, T> Unpin for GenericListBuilder<OffsetSize, T>
impl<OffsetSize, T> UnwindSafe for GenericListBuilder<OffsetSize, T>where
    T: UnwindSafe,
    OffsetSize: UnwindSafe,
Blanket Implementations§
Source§impl<T> AlignerFor<1> for T
 
impl<T> AlignerFor<1> for T
Source§impl<T> AlignerFor<1024> for T
 
impl<T> AlignerFor<1024> for T
Source§type Aligner = AlignTo1024<T>
 
type Aligner = AlignTo1024<T>
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<128> for T
 
impl<T> AlignerFor<128> for T
Source§type Aligner = AlignTo128<T>
 
type Aligner = AlignTo128<T>
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<16> for T
 
impl<T> AlignerFor<16> for T
Source§impl<T> AlignerFor<16384> for T
 
impl<T> AlignerFor<16384> for T
Source§type Aligner = AlignTo16384<T>
 
type Aligner = AlignTo16384<T>
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<2> for T
 
impl<T> AlignerFor<2> for T
Source§impl<T> AlignerFor<2048> for T
 
impl<T> AlignerFor<2048> for T
Source§type Aligner = AlignTo2048<T>
 
type Aligner = AlignTo2048<T>
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<256> for T
 
impl<T> AlignerFor<256> for T
Source§type Aligner = AlignTo256<T>
 
type Aligner = AlignTo256<T>
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<32> for T
 
impl<T> AlignerFor<32> for T
Source§impl<T> AlignerFor<32768> for T
 
impl<T> AlignerFor<32768> for T
Source§type Aligner = AlignTo32768<T>
 
type Aligner = AlignTo32768<T>
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<4> for T
 
impl<T> AlignerFor<4> for T
Source§impl<T> AlignerFor<4096> for T
 
impl<T> AlignerFor<4096> for T
Source§type Aligner = AlignTo4096<T>
 
type Aligner = AlignTo4096<T>
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<512> for T
 
impl<T> AlignerFor<512> for T
Source§type Aligner = AlignTo512<T>
 
type Aligner = AlignTo512<T>
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> AlignerFor<64> for T
 
impl<T> AlignerFor<64> for T
Source§impl<T> AlignerFor<8> for T
 
impl<T> AlignerFor<8> for T
Source§impl<T> AlignerFor<8192> for T
 
impl<T> AlignerFor<8192> for T
Source§type Aligner = AlignTo8192<T>
 
type Aligner = AlignTo8192<T>
AlignTo* type which aligns Self to ALIGNMENT.Source§impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
 
impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
Source§impl<T, W> HasTypeWitness<W> for Twhere
    W: MakeTypeWitness<Arg = T>,
    T: ?Sized,
 
impl<T, W> HasTypeWitness<W> for Twhere
    W: MakeTypeWitness<Arg = T>,
    T: ?Sized,
Source§impl<T> Identity for Twhere
    T: ?Sized,
 
impl<T> Identity for Twhere
    T: ?Sized,
Source§impl<T> Instrument for T
 
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
 
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
 
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
 
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
 
fn into_either(self, into_left: bool) -> Either<Self, Self>
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 moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
 
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
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 moreSource§impl<T> PolicyExt for Twhere
    T: ?Sized,
 
impl<T> PolicyExt for Twhere
    T: ?Sized,
Source§impl<S> ROExtAcc for S
 
impl<S> ROExtAcc for S
Source§fn f_get<F>(&self, offset: FieldOffset<S, F, Aligned>) -> &F
 
fn f_get<F>(&self, offset: FieldOffset<S, F, Aligned>) -> &F
offset. Read moreSource§fn f_get_mut<F>(&mut self, offset: FieldOffset<S, F, Aligned>) -> &mut F
 
fn f_get_mut<F>(&mut self, offset: FieldOffset<S, F, Aligned>) -> &mut F
offset. Read moreSource§fn f_get_ptr<F, A>(&self, offset: FieldOffset<S, F, A>) -> *const F
 
fn f_get_ptr<F, A>(&self, offset: FieldOffset<S, F, A>) -> *const F
offset. Read moreSource§fn f_get_mut_ptr<F, A>(&mut self, offset: FieldOffset<S, F, A>) -> *mut F
 
fn f_get_mut_ptr<F, A>(&mut self, offset: FieldOffset<S, F, A>) -> *mut F
offset. Read moreSource§impl<S> ROExtOps<Aligned> for S
 
impl<S> ROExtOps<Aligned> for S
Source§fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Aligned>, value: F) -> F
 
fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Aligned>, value: F) -> F
offset) with value,
returning the previous value of the field. Read moreSource§fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Aligned>) -> Fwhere
    F: Copy,
 
fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Aligned>) -> Fwhere
    F: Copy,
Source§impl<S> ROExtOps<Unaligned> for S
 
impl<S> ROExtOps<Unaligned> for S
Source§fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Unaligned>, value: F) -> F
 
fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Unaligned>, value: F) -> F
offset) with value,
returning the previous value of the field. Read moreSource§fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Unaligned>) -> Fwhere
    F: Copy,
 
fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Unaligned>) -> Fwhere
    F: Copy,
Source§impl<T> SelfOps for Twhere
    T: ?Sized,
 
impl<T> SelfOps for Twhere
    T: ?Sized,
Source§fn piped<F, U>(self, f: F) -> U
 
fn piped<F, U>(self, f: F) -> U
Source§fn piped_ref<'a, F, U>(&'a self, f: F) -> Uwhere
    F: FnOnce(&'a Self) -> U,
 
fn piped_ref<'a, F, U>(&'a self, f: F) -> Uwhere
    F: FnOnce(&'a Self) -> U,
piped except that the function takes &Self
Useful for functions that take &Self instead of Self. Read moreSource§fn piped_mut<'a, F, U>(&'a mut self, f: F) -> Uwhere
    F: FnOnce(&'a mut Self) -> U,
 
fn piped_mut<'a, F, U>(&'a mut self, f: F) -> Uwhere
    F: FnOnce(&'a mut Self) -> U,
piped, except that the function takes &mut Self.
Useful for functions that take &mut Self instead of Self.Source§fn mutated<F>(self, f: F) -> Self
 
fn mutated<F>(self, f: F) -> Self
Source§fn observe<F>(self, f: F) -> Self
 
fn observe<F>(self, f: F) -> Self
Source§fn as_ref_<T>(&self) -> &T
 
fn as_ref_<T>(&self) -> &T
AsRef,
using the turbofish .as_ref_::<_>() syntax. Read more