Skip to content

Commit

Permalink
fix: VarBinArray into_canonical dtype erasure (#1143)
Browse files Browse the repository at this point in the history
  • Loading branch information
a10y committed Oct 28, 2024
1 parent 1d9e270 commit 737a3c9
Showing 1 changed file with 14 additions and 5 deletions.
19 changes: 14 additions & 5 deletions vortex-array/src/array/varbin/flatten.rs
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
use arrow_schema::DataType;
use vortex_dtype::DType;
use vortex_error::VortexResult;

use crate::array::varbin::arrow::varbin_to_arrow;
Expand All @@ -11,30 +12,38 @@ impl IntoCanonical for VarBinArray {
fn into_canonical(self) -> VortexResult<Canonical> {
let nullable = self.dtype().is_nullable();
let array_ref = varbin_to_arrow(&self)?;
let casted = arrow_cast::cast(array_ref.as_ref(), &DataType::Utf8View)?;
let array = match self.dtype() {
DType::Utf8(_) => arrow_cast::cast(array_ref.as_ref(), &DataType::Utf8View)?,
DType::Binary(_) => arrow_cast::cast(array_ref.as_ref(), &DataType::BinaryView)?,

VarBinViewArray::try_from(Array::from_arrow(casted, nullable)).map(Canonical::VarBinView)
_ => unreachable!("VarBinArray must have Utf8 or Binary dtype"),
};

VarBinViewArray::try_from(Array::from_arrow(array, nullable)).map(Canonical::VarBinView)
}
}

#[cfg(test)]
mod test {
use rstest::rstest;
use vortex_dtype::{DType, Nullability};

use crate::array::varbin::builder::VarBinBuilder;
use crate::validity::ArrayValidity;
use crate::IntoCanonical;

#[test]
fn test_canonical_varbin() {
#[rstest]
#[case(DType::Utf8(Nullability::Nullable))]
#[case(DType::Binary(Nullability::Nullable))]
fn test_canonical_varbin(#[case] dtype: DType) {
let mut varbin = VarBinBuilder::<i32>::with_capacity(10);
varbin.push_null();
varbin.push_null();
// inlined value
varbin.push_value("123456789012".as_bytes());
// non-inlinable value
varbin.push_value("1234567890123".as_bytes());
let varbin = varbin.finish(DType::Utf8(Nullability::Nullable));
let varbin = varbin.finish(dtype);

let canonical = varbin.into_canonical().unwrap().into_varbinview().unwrap();

Expand Down

0 comments on commit 737a3c9

Please sign in to comment.