Skip to main content

qubit_value/multi_values/
multi_values_getter.rs

1/*******************************************************************************
2 *
3 *    Copyright (c) 2025 - 2026 Haixing Hu.
4 *
5 *    SPDX-License-Identifier: Apache-2.0
6 *
7 *    Licensed under the Apache License, Version 2.0.
8 *
9 ******************************************************************************/
10
11//! Internal getter trait implementations for `MultiValues`.
12
13use qubit_datatype::DataType;
14
15use crate::value_error::{
16    ValueError,
17    ValueResult,
18};
19
20use super::multi_values::MultiValues;
21
22/// Internal trait used to extract multiple values from `MultiValues`.
23///
24/// This trait backs `MultiValues::get<T>()`; downstream code should call the
25/// inherent method instead of implementing or naming this trait directly.
26pub trait MultiValuesGetter<T>: super::sealed::MultiValuesGetterSealed<T> {
27    /// Gets all stored values as `Vec<T>`.
28    ///
29    /// # Returns
30    ///
31    /// Returns a cloned vector when the stored variant matches `T`, or a
32    /// `ValueError` describing the mismatch.
33    fn get_values(&self) -> ValueResult<Vec<T>>;
34}
35
36macro_rules! impl_multi_values_getter {
37    ($type:ty, $variant:ident, $data_type:expr) => {
38        impl super::sealed::MultiValuesGetterSealed<$type> for MultiValues {}
39
40        impl MultiValuesGetter<$type> for MultiValues {
41            #[inline]
42            fn get_values(&self) -> ValueResult<Vec<$type>> {
43                match self {
44                    MultiValues::$variant(v) => Ok(v.clone()),
45                    MultiValues::Empty(dt) if *dt == $data_type => Ok(Vec::new()),
46                    _ => Err(ValueError::TypeMismatch {
47                        expected: $data_type,
48                        actual: self.data_type(),
49                    }),
50                }
51            }
52        }
53    };
54}
55
56impl_multi_values_getter!(bool, Bool, DataType::Bool);
57impl_multi_values_getter!(char, Char, DataType::Char);
58impl_multi_values_getter!(i8, Int8, DataType::Int8);
59impl_multi_values_getter!(i16, Int16, DataType::Int16);
60impl_multi_values_getter!(i32, Int32, DataType::Int32);
61impl_multi_values_getter!(i64, Int64, DataType::Int64);
62impl_multi_values_getter!(i128, Int128, DataType::Int128);
63impl_multi_values_getter!(u8, UInt8, DataType::UInt8);
64impl_multi_values_getter!(u16, UInt16, DataType::UInt16);
65impl_multi_values_getter!(u32, UInt32, DataType::UInt32);
66impl_multi_values_getter!(u64, UInt64, DataType::UInt64);
67impl_multi_values_getter!(u128, UInt128, DataType::UInt128);
68impl_multi_values_getter!(f32, Float32, DataType::Float32);
69impl_multi_values_getter!(f64, Float64, DataType::Float64);
70impl_multi_values_getter!(String, String, DataType::String);
71impl_multi_values_getter!(chrono::NaiveDate, Date, DataType::Date);
72impl_multi_values_getter!(chrono::NaiveTime, Time, DataType::Time);
73impl_multi_values_getter!(chrono::NaiveDateTime, DateTime, DataType::DateTime);
74impl_multi_values_getter!(chrono::DateTime<chrono::Utc>, Instant, DataType::Instant);
75impl_multi_values_getter!(num_bigint::BigInt, BigInteger, DataType::BigInteger);
76impl_multi_values_getter!(bigdecimal::BigDecimal, BigDecimal, DataType::BigDecimal);
77impl_multi_values_getter!(isize, IntSize, DataType::IntSize);
78impl_multi_values_getter!(usize, UIntSize, DataType::UIntSize);
79impl_multi_values_getter!(std::time::Duration, Duration, DataType::Duration);
80impl_multi_values_getter!(url::Url, Url, DataType::Url);
81impl_multi_values_getter!(std::collections::HashMap<String, String>, StringMap, DataType::StringMap);
82impl_multi_values_getter!(serde_json::Value, Json, DataType::Json);