use std::sync::Arc;
use vortex_error::VortexResult;
use vortex_session::VortexSession;
use crate::ArrayRef;
use crate::IntoArray;
use crate::array::Array;
use crate::array::ArrayId;
use crate::array::VTable;
use crate::buffer::BufferHandle;
use crate::dtype::DType;
use crate::serde::ArrayChildren;
pub type ArrayPluginRef = Arc<dyn ArrayPlugin>;
pub trait ArrayPlugin: 'static + Send + Sync {
fn id(&self) -> ArrayId;
fn serialize(&self, array: &ArrayRef, session: &VortexSession)
-> VortexResult<Option<Vec<u8>>>;
#[allow(clippy::too_many_arguments)]
fn deserialize(
&self,
dtype: &DType,
len: usize,
metadata: &[u8],
buffers: &[BufferHandle],
children: &dyn ArrayChildren,
session: &VortexSession,
) -> VortexResult<ArrayRef>;
}
impl std::fmt::Debug for dyn ArrayPlugin {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
f.debug_tuple("ArrayPlugin").field(&self.id()).finish()
}
}
impl<V: VTable> ArrayPlugin for V {
fn id(&self) -> ArrayId {
VTable::id(self)
}
fn serialize(
&self,
array: &ArrayRef,
session: &VortexSession,
) -> VortexResult<Option<Vec<u8>>> {
assert_eq!(
self.id(),
array.encoding_id(),
"Invoked for incorrect array ID"
);
V::serialize(array.as_::<V>(), session)
}
fn deserialize(
&self,
dtype: &DType,
len: usize,
metadata: &[u8],
buffers: &[BufferHandle],
children: &dyn ArrayChildren,
session: &VortexSession,
) -> VortexResult<ArrayRef> {
Ok(Array::<V>::try_from_parts(V::deserialize(
self, dtype, len, metadata, buffers, children, session,
)?)?
.into_array())
}
}