teo_runtime/value/convert/into/
index_map.rs

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
use std::fmt::Display;
use indexmap::IndexMap;
use teo_result::Error;
use crate::value::Value;

impl<T> TryInto<IndexMap<String, T>> for Value where T: TryFrom<Value>, T::Error: Display {

    type Error = Error;

    fn try_into(self) -> Result<IndexMap<String, T>, Self::Error> {
        match self {
            Value::Dictionary(map) => {
                let mut result: IndexMap<String, T> = IndexMap::new();
                for (k, v) in map {
                    result.insert(k, v.try_into().map_err(|e: T::Error| Error::new(format!("{}", e)))?);
                }
                Ok(result)
            }
            _ => Err(Error::new(format!("Cannot convert {} into IndexMap", self.type_hint()))),
        }
    }
}

impl<'a, T> TryInto<IndexMap<String, T>> for &'a Value where T: TryFrom<&'a Value>, T::Error: Display {

    type Error = Error;

    fn try_into(self) -> Result<IndexMap<String, T>, Self::Error> {
        match self {
            Value::Dictionary(map) => {
                let mut result: IndexMap<String, T> = IndexMap::new();
                for (k, v) in map {
                    result.insert(k.to_owned(), v.try_into().map_err(|e: T::Error| Error::new(format!("{}", e)))?);
                }
                Ok(result)
            }
            _ => Err(Error::new(format!("Cannot convert {} into IndexMap", self.type_hint()))),
        }
    }
}

impl<T> TryInto<Option<IndexMap<String, T>>> for Value where T: TryFrom<Value>, T::Error: Display {

    type Error = Error;

    fn try_into(self) -> Result<Option<IndexMap<String, T>>, Self::Error> {
        match self {
            Value::Null => Ok(None),
            Value::Dictionary(map) => {
                let mut result: IndexMap<String, T> = IndexMap::new();
                for (k, v) in map {
                    result.insert(k, v.try_into().map_err(|e: T::Error| Error::new(format!("{}", e)))?);
                }
                Ok(Some(result))
            }
            _ => Err(Error::new(format!("Cannot convert {} into Option<IndexMap>", self.type_hint()))),
        }
    }
}

impl<'a, T> TryInto<Option<IndexMap<String, T>>> for &'a Value where T: TryFrom<&'a Value>, T::Error: Display {

    type Error = Error;

    fn try_into(self) -> Result<Option<IndexMap<String, T>>, Self::Error> {
        match self {
            Value::Null => Ok(None),
            Value::Dictionary(map) => {
                let mut result: IndexMap<String, T> = IndexMap::new();
                for (k, v) in map {
                    result.insert(k.to_owned(), v.try_into().map_err(|e: T::Error| Error::new(format!("{}", e)))?);
                }
                Ok(Some(result))
            }
            _ => Err(Error::new(format!("Cannot convert {} into Option<IndexMap>", self.type_hint()))),
        }
    }
}

impl<'a> TryFrom<&'a Value> for &'a IndexMap<String, Value> {
    type Error = Error;

    fn try_from(value: &'a Value) -> Result<Self, Self::Error> {
        match value {
            Value::Dictionary(inner) => Ok(inner),
            _ => Err(Error::new(format!("cannot convert to &IndexMap<String, Value>: {}", value)))
        }
    }
}