diff --git a/src/daft-core/src/array/iterator.rs b/src/daft-core/src/array/iterator.rs index 0474f2b560..8ddc0bffc1 100644 --- a/src/daft-core/src/array/iterator.rs +++ b/src/daft-core/src/array/iterator.rs @@ -1,26 +1,78 @@ -use arrow2::bitmap::utils::{BitmapIter, ZipValidity}; +use std::{ + iter::{repeat, Repeat, Take}, + slice::{ChunksExact, Iter}, +}; -use super::{ops::as_arrow::AsArrow, DataArray}; -use crate::datatypes::{BooleanArray, DaftPrimitiveType}; +use arrow2::{ + array::ArrayValuesIter, + bitmap::utils::{BitmapIter, ZipValidity}, +}; + +use crate::{ + array::{ + ops::as_arrow::AsArrow, + prelude::{NullArray, Utf8Array}, + DataArray, + }, + datatypes::{BinaryArray, BooleanArray, DaftPrimitiveType, FixedSizeBinaryArray}, +}; + +macro_rules! impl_into_iter { + ( + $array:ty + , $into_iter:ty + $(,)? + ) => { + impl<'a> IntoIterator for &'a $array { + type IntoIter = $into_iter; + type Item = ::Item; + + #[inline] + fn into_iter(self) -> Self::IntoIter { + self.as_arrow().into_iter() + } + } + }; +} + +// yields `bool`s +impl_into_iter!(BooleanArray, ZipValidity, BitmapIter<'a>>); + +// both yield `&[u8]`s +impl_into_iter!( + BinaryArray, + ZipValidity<&'a [u8], ArrayValuesIter<'a, arrow2::array::BinaryArray>, BitmapIter<'a>>, +); +impl_into_iter!( + FixedSizeBinaryArray, + ZipValidity<&'a [u8], ChunksExact<'a, u8>, BitmapIter<'a>>, +); + +// yields `&str`s +impl_into_iter!( + Utf8Array, + ZipValidity<&'a str, ArrayValuesIter<'a, arrow2::array::Utf8Array>, BitmapIter<'a>>, +); impl<'a, T> IntoIterator for &'a DataArray where T: DaftPrimitiveType, { - type Item = Option<&'a T::Native>; - type IntoIter = ZipValidity<&'a T::Native, std::slice::Iter<'a, T::Native>, BitmapIter<'a>>; + type IntoIter = ZipValidity<&'a T::Native, Iter<'a, T::Native>, BitmapIter<'a>>; + type Item = ::Item; + #[inline] fn into_iter(self) -> Self::IntoIter { self.as_arrow().into_iter() } } -impl<'a> IntoIterator for &'a BooleanArray { - type Item = Option; - type IntoIter = ZipValidity, BitmapIter<'a>>; +impl<'a> IntoIterator for &'a NullArray { + type IntoIter = Take>>; + type Item = ::Item; #[inline] fn into_iter(self) -> Self::IntoIter { - self.as_arrow().into_iter() + repeat(None).take(self.len()) } }