Path: blob/main/crates/polars-arrow/src/array/primitive/iterator.rs
8390 views
use super::{MutablePrimitiveArray, PrimitiveArray};1use crate::array::{ArrayAccessor, MutableArray};2use crate::bitmap::IntoIter as BitmapIntoIter;3use crate::bitmap::utils::{BitmapIter, ZipValidity};4use crate::types::NativeType;56unsafe impl<'a, T: NativeType> ArrayAccessor<'a> for [T] {7type Item = T;89#[inline]10unsafe fn value_unchecked(&'a self, index: usize) -> Self::Item {11*self.get_unchecked(index)12}1314#[inline]15fn len(&self) -> usize {16(*self).len()17}18}1920impl<T: NativeType> IntoIterator for PrimitiveArray<T> {21type Item = Option<T>;22type IntoIter = ZipValidity<T, polars_buffer::buffer::IntoIter<T>, BitmapIntoIter>;2324#[inline]25fn into_iter(self) -> Self::IntoIter {26let (_, values, validity) = self.into_inner();27let values = values.into_iter();28let validity =29validity.and_then(|validity| (validity.unset_bits() > 0).then(|| validity.into_iter()));30ZipValidity::new(values, validity)31}32}3334impl<'a, T: NativeType> IntoIterator for &'a PrimitiveArray<T> {35type Item = Option<&'a T>;36type IntoIter = ZipValidity<&'a T, std::slice::Iter<'a, T>, BitmapIter<'a>>;3738#[inline]39fn into_iter(self) -> Self::IntoIter {40self.iter()41}42}4344impl<'a, T: NativeType> MutablePrimitiveArray<T> {45/// Returns an iterator over `Option<T>`46#[inline]47pub fn iter(&'a self) -> ZipValidity<&'a T, std::slice::Iter<'a, T>, BitmapIter<'a>> {48ZipValidity::new(49self.values().iter(),50self.validity().as_ref().map(|x| x.iter()),51)52}5354/// Returns an iterator of `T`55#[inline]56pub fn values_iter(&'a self) -> std::slice::Iter<'a, T> {57self.values().iter()58}59}606162