vortex_array/arrays/bool/vtable/
operations.rs1use vortex_error::VortexResult;
5
6use crate::ExecutionCtx;
7use crate::array::ArrayView;
8use crate::array::OperationsVTable;
9use crate::arrays::Bool;
10use crate::arrays::bool::BoolArrayExt;
11use crate::scalar::Scalar;
12
13impl OperationsVTable<Bool> for Bool {
14 fn scalar_at(
15 array: ArrayView<'_, Bool>,
16 index: usize,
17 _ctx: &mut ExecutionCtx,
18 ) -> VortexResult<Scalar> {
19 Ok(Scalar::bool(
20 array.bit_buffer_view().value(index),
21 array.dtype().nullability(),
22 ))
23 }
24}
25
26#[cfg(test)]
27mod tests {
28 use std::iter;
29
30 use crate::IntoArray;
31 #[expect(deprecated)]
32 use crate::ToCanonical as _;
33 use crate::VortexSessionExecute;
34 use crate::array_session;
35 use crate::arrays::BoolArray;
36 use crate::arrays::bool::BoolArrayExt;
37 use crate::assert_arrays_eq;
38
39 #[test]
40 fn test_slice_hundred_elements() {
41 let arr = BoolArray::from_iter(iter::repeat_n(Some(true), 100));
42 #[expect(deprecated)]
43 let sliced_arr = arr.into_array().slice(8..16).unwrap().to_bool();
44 assert_eq!(sliced_arr.len(), 8);
45 assert_eq!(sliced_arr.to_bit_buffer().len(), 8);
46 assert_eq!(sliced_arr.to_bit_buffer().offset(), 0);
47 }
48
49 #[test]
50 fn test_slice() {
51 let mut ctx = array_session().create_execution_ctx();
52 let arr = BoolArray::from_iter([Some(true), Some(true), None, Some(false), None]);
53 #[expect(deprecated)]
54 let sliced_arr = arr.into_array().slice(1..4).unwrap().to_bool();
55
56 assert_arrays_eq!(
57 sliced_arr,
58 BoolArray::from_iter([Some(true), None, Some(false)]),
59 &mut ctx
60 );
61 }
62}