|
20 | 20 | //! but provide an error message rather than a panic, as the corresponding |
21 | 21 | //! kernels in arrow-rs such as `as_boolean_array` do. |
22 | 22 |
|
23 | | -use crate::DataFusionError; |
| 23 | +use crate::{downcast_value, DataFusionError}; |
24 | 24 | use arrow::array::{ |
25 | 25 | Array, BooleanArray, Date32Array, Decimal128Array, Float32Array, Float64Array, |
26 | | - Int32Array, Int64Array, StringArray, StructArray, UInt32Array, UInt64Array, |
| 26 | + Int32Array, Int64Array, ListArray, StringArray, StructArray, UInt32Array, |
| 27 | + UInt64Array, |
27 | 28 | }; |
28 | 29 |
|
29 | 30 | // Downcast ArrayRef to Date32Array |
30 | 31 | pub fn as_date32_array(array: &dyn Array) -> Result<&Date32Array, DataFusionError> { |
31 | | - array.as_any().downcast_ref::<Date32Array>().ok_or_else(|| { |
32 | | - DataFusionError::Internal(format!( |
33 | | - "Expected a Date32Array, got: {}", |
34 | | - array.data_type() |
35 | | - )) |
36 | | - }) |
| 32 | + Ok(downcast_value!(array, Date32Array)) |
37 | 33 | } |
38 | 34 |
|
39 | 35 | // Downcast ArrayRef to StructArray |
40 | 36 | pub fn as_struct_array(array: &dyn Array) -> Result<&StructArray, DataFusionError> { |
41 | | - array.as_any().downcast_ref::<StructArray>().ok_or_else(|| { |
42 | | - DataFusionError::Internal(format!( |
43 | | - "Expected a StructArray, got: {}", |
44 | | - array.data_type() |
45 | | - )) |
46 | | - }) |
| 37 | + Ok(downcast_value!(array, StructArray)) |
47 | 38 | } |
48 | 39 |
|
49 | 40 | // Downcast ArrayRef to Int32Array |
50 | 41 | pub fn as_int32_array(array: &dyn Array) -> Result<&Int32Array, DataFusionError> { |
51 | | - array.as_any().downcast_ref::<Int32Array>().ok_or_else(|| { |
52 | | - DataFusionError::Internal(format!( |
53 | | - "Expected a Int32Array, got: {}", |
54 | | - array.data_type() |
55 | | - )) |
56 | | - }) |
| 42 | + Ok(downcast_value!(array, Int32Array)) |
57 | 43 | } |
58 | 44 |
|
59 | 45 | // Downcast ArrayRef to Int64Array |
60 | 46 | pub fn as_int64_array(array: &dyn Array) -> Result<&Int64Array, DataFusionError> { |
61 | | - array.as_any().downcast_ref::<Int64Array>().ok_or_else(|| { |
62 | | - DataFusionError::Internal(format!( |
63 | | - "Expected a Int64Array, got: {}", |
64 | | - array.data_type() |
65 | | - )) |
66 | | - }) |
| 47 | + Ok(downcast_value!(array, Int64Array)) |
67 | 48 | } |
68 | 49 |
|
69 | 50 | // Downcast ArrayRef to Decimal128Array |
70 | 51 | pub fn as_decimal128_array( |
71 | 52 | array: &dyn Array, |
72 | 53 | ) -> Result<&Decimal128Array, DataFusionError> { |
73 | | - array |
74 | | - .as_any() |
75 | | - .downcast_ref::<Decimal128Array>() |
76 | | - .ok_or_else(|| { |
77 | | - DataFusionError::Internal(format!( |
78 | | - "Expected a Decimal128Array, got: {}", |
79 | | - array.data_type() |
80 | | - )) |
81 | | - }) |
| 54 | + Ok(downcast_value!(array, Decimal128Array)) |
82 | 55 | } |
83 | 56 |
|
84 | 57 | // Downcast ArrayRef to Float32Array |
85 | 58 | pub fn as_float32_array(array: &dyn Array) -> Result<&Float32Array, DataFusionError> { |
86 | | - array |
87 | | - .as_any() |
88 | | - .downcast_ref::<Float32Array>() |
89 | | - .ok_or_else(|| { |
90 | | - DataFusionError::Internal(format!( |
91 | | - "Expected a Float32Array, got: {}", |
92 | | - array.data_type() |
93 | | - )) |
94 | | - }) |
| 59 | + Ok(downcast_value!(array, Float32Array)) |
95 | 60 | } |
96 | 61 |
|
97 | 62 | // Downcast ArrayRef to Float64Array |
98 | 63 | pub fn as_float64_array(array: &dyn Array) -> Result<&Float64Array, DataFusionError> { |
99 | | - array |
100 | | - .as_any() |
101 | | - .downcast_ref::<Float64Array>() |
102 | | - .ok_or_else(|| { |
103 | | - DataFusionError::Internal(format!( |
104 | | - "Expected a Float64Array, got: {}", |
105 | | - array.data_type() |
106 | | - )) |
107 | | - }) |
| 64 | + Ok(downcast_value!(array, Float64Array)) |
108 | 65 | } |
109 | 66 |
|
110 | 67 | // Downcast ArrayRef to StringArray |
111 | 68 | pub fn as_string_array(array: &dyn Array) -> Result<&StringArray, DataFusionError> { |
112 | | - array.as_any().downcast_ref::<StringArray>().ok_or_else(|| { |
113 | | - DataFusionError::Internal(format!( |
114 | | - "Expected a StringArray, got: {}", |
115 | | - array.data_type() |
116 | | - )) |
117 | | - }) |
| 69 | + Ok(downcast_value!(array, StringArray)) |
118 | 70 | } |
119 | 71 |
|
120 | 72 | // Downcast ArrayRef to UInt32Array |
121 | 73 | pub fn as_uint32_array(array: &dyn Array) -> Result<&UInt32Array, DataFusionError> { |
122 | | - array.as_any().downcast_ref::<UInt32Array>().ok_or_else(|| { |
123 | | - DataFusionError::Internal(format!( |
124 | | - "Expected a UInt32Array, got: {}", |
125 | | - array.data_type() |
126 | | - )) |
127 | | - }) |
| 74 | + Ok(downcast_value!(array, UInt32Array)) |
128 | 75 | } |
129 | 76 |
|
130 | 77 | // Downcast ArrayRef to UInt64Array |
131 | 78 | pub fn as_uint64_array(array: &dyn Array) -> Result<&UInt64Array, DataFusionError> { |
132 | | - array.as_any().downcast_ref::<UInt64Array>().ok_or_else(|| { |
133 | | - DataFusionError::Internal(format!( |
134 | | - "Expected a UInt64Array, got: {}", |
135 | | - array.data_type() |
136 | | - )) |
137 | | - }) |
| 79 | + Ok(downcast_value!(array, UInt64Array)) |
138 | 80 | } |
139 | 81 |
|
140 | 82 | // Downcast ArrayRef to BooleanArray |
141 | 83 | pub fn as_boolean_array(array: &dyn Array) -> Result<&BooleanArray, DataFusionError> { |
142 | | - array |
143 | | - .as_any() |
144 | | - .downcast_ref::<BooleanArray>() |
145 | | - .ok_or_else(|| { |
146 | | - DataFusionError::Internal(format!( |
147 | | - "Expected a BooleanArray, got: {}", |
148 | | - array.data_type() |
149 | | - )) |
150 | | - }) |
| 84 | + Ok(downcast_value!(array, BooleanArray)) |
| 85 | +} |
| 86 | + |
| 87 | +// Downcast ArrayRef to ListArray |
| 88 | +pub fn as_list_array(array: &dyn Array) -> Result<&ListArray, DataFusionError> { |
| 89 | + Ok(downcast_value!(array, ListArray)) |
151 | 90 | } |
0 commit comments