arrow_array/builder/
null_builder.rs1use crate::builder::ArrayBuilder;
19use crate::{ArrayRef, NullArray};
20use arrow_data::ArrayData;
21use arrow_schema::DataType;
22use std::any::Any;
23use std::sync::Arc;
24
25#[derive(Debug)]
46pub struct NullBuilder {
47 len: usize,
48}
49
50impl Default for NullBuilder {
51 fn default() -> Self {
52 Self::new()
53 }
54}
55
56impl NullBuilder {
57 pub fn new() -> Self {
59 Self { len: 0 }
60 }
61
62 #[inline]
64 pub fn append_null(&mut self) {
65 self.len += 1;
66 }
67
68 #[inline]
70 pub fn append_nulls(&mut self, n: usize) {
71 self.len += n;
72 }
73
74 #[inline]
76 pub fn append_empty_value(&mut self) {
77 self.append_null();
78 }
79
80 #[inline]
82 pub fn append_empty_values(&mut self, n: usize) {
83 self.append_nulls(n);
84 }
85
86 pub fn finish(&mut self) -> NullArray {
88 let len = self.len();
89 let builder = ArrayData::new_null(&DataType::Null, len).into_builder();
90
91 let array_data = unsafe { builder.build_unchecked() };
92 NullArray::from(array_data)
93 }
94
95 pub fn finish_cloned(&self) -> NullArray {
97 let len = self.len();
98 let builder = ArrayData::new_null(&DataType::Null, len).into_builder();
99
100 let array_data = unsafe { builder.build_unchecked() };
101 NullArray::from(array_data)
102 }
103}
104
105impl ArrayBuilder for NullBuilder {
106 fn as_any(&self) -> &dyn Any {
108 self
109 }
110
111 fn as_any_mut(&mut self) -> &mut dyn Any {
113 self
114 }
115
116 fn into_box_any(self: Box<Self>) -> Box<dyn Any> {
118 self
119 }
120
121 fn len(&self) -> usize {
123 self.len
124 }
125
126 fn finish(&mut self) -> ArrayRef {
128 Arc::new(self.finish())
129 }
130
131 fn finish_cloned(&self) -> ArrayRef {
133 Arc::new(self.finish_cloned())
134 }
135}
136
137#[cfg(test)]
138mod tests {
139 use super::*;
140 use crate::Array;
141
142 #[test]
143 fn test_null_array_builder() {
144 let mut builder = NullArray::builder(10);
145 builder.append_null();
146 builder.append_nulls(4);
147 builder.append_empty_value();
148 builder.append_empty_values(4);
149
150 let arr = builder.finish();
151 assert_eq!(10, arr.len());
152 assert_eq!(0, arr.offset());
153 assert_eq!(0, arr.null_count());
154 assert!(arr.is_nullable());
155 }
156
157 #[test]
158 fn test_null_array_builder_finish_cloned() {
159 let mut builder = NullArray::builder(16);
160 builder.append_null();
161 builder.append_empty_value();
162 builder.append_empty_values(3);
163 let mut array = builder.finish_cloned();
164 assert_eq!(5, array.len());
165
166 builder.append_empty_values(5);
167 array = builder.finish();
168 assert_eq!(10, array.len());
169 }
170}