Skip to content
This repository has been archived by the owner on Feb 18, 2024. It is now read-only.

Commit

Permalink
Improved cast to/from Null (#1066)
Browse files Browse the repository at this point in the history
  • Loading branch information
jorgecarleitao authored Jun 10, 2022
1 parent 6919cc3 commit a3f050a
Showing 1 changed file with 2 additions and 20 deletions.
22 changes: 2 additions & 20 deletions src/compute/cast/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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)) => {
Expand Down Expand Up @@ -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(),
)),
Expand Down

0 comments on commit a3f050a

Please sign in to comment.