use vortex_error::VortexResult;
use vortex_session::VortexSession;
use crate::ArrayId;
use crate::ArrayPlugin;
use crate::ArrayRef;
use crate::IntoArray;
use crate::arrays::ScalarFnArray;
use crate::arrays::scalar_fn::ExactScalarFn;
use crate::arrays::scalar_fn::ScalarFnArrayView;
use crate::buffer::BufferHandle;
use crate::dtype::DType;
use crate::scalar_fn::ScalarFn;
use crate::scalar_fn::ScalarFnVTable;
use crate::serde::ArrayChildren;
pub struct ScalarFnArrayPlugin<V: ScalarFnVTable>(V);
impl<V: ScalarFnVTable> ScalarFnArrayPlugin<V> {
pub fn new(vtable: V) -> Self {
Self(vtable)
}
}
pub trait ScalarFnArrayVTable: ScalarFnVTable {
fn serialize(
&self,
view: &ScalarFnArrayView<Self>,
session: &VortexSession,
) -> VortexResult<Option<Vec<u8>>>;
fn deserialize(
&self,
dtype: &DType,
len: usize,
metadata: &[u8],
children: &dyn ArrayChildren,
session: &VortexSession,
) -> VortexResult<ScalarFnArrayParts<Self>>;
}
pub struct ScalarFnArrayParts<V: ScalarFnVTable> {
pub options: V::Options,
pub children: Vec<ArrayRef>,
}
impl<V: ScalarFnVTable + ScalarFnArrayVTable> ArrayPlugin for ScalarFnArrayPlugin<V> {
fn id(&self) -> ArrayId {
self.0.id()
}
fn serialize(
&self,
array: &ArrayRef,
session: &VortexSession,
) -> VortexResult<Option<Vec<u8>>> {
let scalar_fn = array.as_::<ExactScalarFn<V>>();
<V as ScalarFnArrayVTable>::serialize(&self.0, &scalar_fn, session)
}
fn deserialize(
&self,
dtype: &DType,
len: usize,
metadata: &[u8],
_buffers: &[BufferHandle],
children: &dyn ArrayChildren,
session: &VortexSession,
) -> VortexResult<ArrayRef> {
let parts = <V as ScalarFnArrayVTable>::deserialize(
&self.0, dtype, len, metadata, children, session,
)?;
Ok(ScalarFnArray::try_new(
ScalarFn::new(self.0.clone(), parts.options).erased(),
parts.children,
len,
)?
.into_array())
}
}