polars_core/chunked_array/builder/
primitive.rs1use super::*;
2
3#[derive(Clone)]
4pub struct PrimitiveChunkedBuilder<T>
5where
6 T: PolarsNumericType,
7{
8 array_builder: MutablePrimitiveArray<T::Native>,
9 pub(crate) field: Field,
10}
11
12impl<T> ChunkedBuilder<T::Native, T> for PrimitiveChunkedBuilder<T>
13where
14 T: PolarsNumericType,
15{
16 #[inline]
18 fn append_value(&mut self, v: T::Native) {
19 self.array_builder.push(Some(v))
20 }
21
22 #[inline]
24 fn append_null(&mut self) {
25 self.array_builder.push(None)
26 }
27
28 fn finish(mut self) -> ChunkedArray<T> {
29 let arr = self.array_builder.as_box();
30 ChunkedArray::new_with_compute_len(Arc::new(self.field), vec![arr])
31 }
32
33 fn shrink_to_fit(&mut self) {
34 self.array_builder.shrink_to_fit()
35 }
36}
37
38impl<T> PrimitiveChunkedBuilder<T>
39where
40 T: PolarsNumericType,
41{
42 pub fn new(name: PlSmallStr, capacity: usize) -> Self {
43 let array_builder = MutablePrimitiveArray::<T::Native>::with_capacity(capacity)
44 .to(T::get_dtype().to_arrow(CompatLevel::newest()));
45
46 PrimitiveChunkedBuilder {
47 array_builder,
48 field: Field::new(name, T::get_dtype()),
49 }
50 }
51}