From a3f050aca79920785c5bdee8e013e86d3aceb79e Mon Sep 17 00:00:00 2001 From: Jorge Leitao Date: Fri, 10 Jun 2022 17:08:49 +0200 Subject: [PATCH] Improved cast to/from Null (#1066) --- src/compute/cast/mod.rs | 22 ++-------------------- 1 file changed, 2 insertions(+), 20 deletions(-) diff --git a/src/compute/cast/mod.rs b/src/compute/cast/mod.rs index f236473e883..2cae7a21923 100644 --- a/src/compute/cast/mod.rs +++ b/src/compute/cast/mod.rs @@ -79,16 +79,7 @@ pub fn can_cast_types(from_type: &DataType, to_type: &DataType) -> bool { } match (from_type, to_type) { - ( - Null, - Boolean | Int8 | UInt8 | Int16 | UInt16 | Int32 | UInt32 | Float32 | Date32 | Time32(_) - | Int64 | UInt64 | Float64 | Date64 | List(_) | Dictionary(..), - ) - | ( - Boolean | Int8 | UInt8 | Int16 | UInt16 | Int32 | UInt32 | Float32 | Date32 | Time32(_) - | Int64 | UInt64 | Float64 | Date64 | List(_) | Dictionary(..), - Null, - ) => true, + (Null, _) | (_, Null) => true, (Struct(_), _) => false, (_, Struct(_)) => false, (List(list_from), List(list_to)) => { @@ -379,16 +370,7 @@ pub fn cast(array: &dyn Array, to_type: &DataType, options: CastOptions) -> Resu let as_options = options.with_wrapped(true); match (from_type, to_type) { - ( - Null, - Boolean | Int8 | UInt8 | Int16 | UInt16 | Int32 | UInt32 | Float32 | Date32 | Time32(_) - | Int64 | UInt64 | Float64 | Date64 | List(_) | Dictionary(..), - ) - | ( - Boolean | Int8 | UInt8 | Int16 | UInt16 | Int32 | UInt32 | Float32 | Date32 | Time32(_) - | Int64 | UInt64 | Float64 | Date64 | List(_) | Dictionary(..), - Null, - ) => Ok(new_null_array(to_type.clone(), array.len())), + (Null, _) | (_, Null) => Ok(new_null_array(to_type.clone(), array.len())), (Struct(_), _) => Err(Error::NotYetImplemented( "Cannot cast from struct to other types".to_string(), )),