use std::fmt::Display;
use std::fmt::Formatter;
use vortex_array::ArrayRef;
use vortex_array::TypedArrayRef;
use vortex_array::dtype::PType;
use vortex_array::scalar::Scalar;
use vortex_error::VortexExpect as _;
use vortex_error::VortexResult;
use vortex_error::vortex_ensure;
pub mod for_compress;
pub mod for_decompress;
pub(super) const ENCODED_SLOT: usize = 0;
pub(super) const NUM_SLOTS: usize = 1;
pub(super) const SLOT_NAMES: [&str; NUM_SLOTS] = ["encoded"];
#[derive(Clone, Debug)]
pub struct FoRData {
pub(super) reference: Scalar,
}
pub trait FoRArrayExt: TypedArrayRef<crate::FoR> {
fn encoded(&self) -> &ArrayRef {
self.as_ref().slots()[ENCODED_SLOT]
.as_ref()
.vortex_expect("FoRArray encoded slot")
}
fn reference_scalar(&self) -> &Scalar {
&self.reference
}
}
impl<T: TypedArrayRef<crate::FoR>> FoRArrayExt for T {}
impl Display for FoRData {
fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
write!(f, "reference: {}", self.reference)
}
}
impl FoRData {
pub(crate) fn try_new(reference: Scalar) -> VortexResult<Self> {
vortex_ensure!(!reference.is_null(), "Reference value cannot be null");
vortex_ensure!(
reference.dtype().is_int(),
"FoR requires an integer reference dtype, got {}",
reference.dtype()
);
Ok(Self { reference })
}
#[inline]
pub fn ptype(&self) -> PType {
self.reference.dtype().as_ptype()
}
}