use std::ops::Range;
use std::sync::Arc;
use vortex_scalar::Scalar;
use crate::arrays::{ListViewArray, ListViewVTable};
use crate::vtable::OperationsVTable;
use crate::{ArrayRef, IntoArray};
impl OperationsVTable<ListViewVTable> for ListViewVTable {
fn slice(array: &ListViewArray, range: Range<usize>) -> ArrayRef {
let start = range.start;
let end = range.end;
unsafe {
ListViewArray::new_unchecked(
array.elements().clone(),
array.offsets().slice(start..end),
array.sizes().slice(start..end),
array.validity.slice(start..end),
)
}
.into_array()
}
fn scalar_at(array: &ListViewArray, index: usize) -> Scalar {
let list = array.list_elements_at(index);
let children: Vec<Scalar> = (0..list.len()).map(|i| list.scalar_at(i)).collect();
Scalar::list(
Arc::new(list.dtype().clone()),
children,
array.dtype.nullability(),
)
}
}