Skip to main content

nominal_api/conjure/objects/scout/compute/api/
bit_operation_function.rs

1use conjure_object::serde::{ser, de};
2use conjure_object::serde::ser::SerializeMap as SerializeMap_;
3use conjure_object::private::{UnionField_, UnionTypeField_};
4use std::fmt;
5#[derive(Debug, Clone, PartialEq, Eq, PartialOrd, Ord, Hash)]
6pub enum BitOperationFunction {
7    And(super::BitAndFunction),
8    Or(super::BitOrFunction),
9    Xor(super::BitXorFunction),
10    ShiftRight(super::BitShiftRightFunction),
11    ShiftLeft(super::BitShiftLeftFunction),
12    BitTest(super::BitTestFunction),
13    /// An unknown variant.
14    Unknown(Unknown),
15}
16impl ser::Serialize for BitOperationFunction {
17    fn serialize<S>(&self, s: S) -> Result<S::Ok, S::Error>
18    where
19        S: ser::Serializer,
20    {
21        let mut map = s.serialize_map(Some(2))?;
22        match self {
23            BitOperationFunction::And(value) => {
24                map.serialize_entry(&"type", &"and")?;
25                map.serialize_entry(&"and", value)?;
26            }
27            BitOperationFunction::Or(value) => {
28                map.serialize_entry(&"type", &"or")?;
29                map.serialize_entry(&"or", value)?;
30            }
31            BitOperationFunction::Xor(value) => {
32                map.serialize_entry(&"type", &"xor")?;
33                map.serialize_entry(&"xor", value)?;
34            }
35            BitOperationFunction::ShiftRight(value) => {
36                map.serialize_entry(&"type", &"shiftRight")?;
37                map.serialize_entry(&"shiftRight", value)?;
38            }
39            BitOperationFunction::ShiftLeft(value) => {
40                map.serialize_entry(&"type", &"shiftLeft")?;
41                map.serialize_entry(&"shiftLeft", value)?;
42            }
43            BitOperationFunction::BitTest(value) => {
44                map.serialize_entry(&"type", &"bitTest")?;
45                map.serialize_entry(&"bitTest", value)?;
46            }
47            BitOperationFunction::Unknown(value) => {
48                map.serialize_entry(&"type", &value.type_)?;
49                map.serialize_entry(&value.type_, &value.value)?;
50            }
51        }
52        map.end()
53    }
54}
55impl<'de> de::Deserialize<'de> for BitOperationFunction {
56    fn deserialize<D>(d: D) -> Result<BitOperationFunction, D::Error>
57    where
58        D: de::Deserializer<'de>,
59    {
60        d.deserialize_map(Visitor_)
61    }
62}
63struct Visitor_;
64impl<'de> de::Visitor<'de> for Visitor_ {
65    type Value = BitOperationFunction;
66    fn expecting(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
67        fmt.write_str("union BitOperationFunction")
68    }
69    fn visit_map<A>(self, mut map: A) -> Result<BitOperationFunction, A::Error>
70    where
71        A: de::MapAccess<'de>,
72    {
73        let v = match map.next_key::<UnionField_<Variant_>>()? {
74            Some(UnionField_::Type) => {
75                let variant = map.next_value()?;
76                let key = map.next_key()?;
77                match (variant, key) {
78                    (Variant_::And, Some(Variant_::And)) => {
79                        let value = map.next_value()?;
80                        BitOperationFunction::And(value)
81                    }
82                    (Variant_::Or, Some(Variant_::Or)) => {
83                        let value = map.next_value()?;
84                        BitOperationFunction::Or(value)
85                    }
86                    (Variant_::Xor, Some(Variant_::Xor)) => {
87                        let value = map.next_value()?;
88                        BitOperationFunction::Xor(value)
89                    }
90                    (Variant_::ShiftRight, Some(Variant_::ShiftRight)) => {
91                        let value = map.next_value()?;
92                        BitOperationFunction::ShiftRight(value)
93                    }
94                    (Variant_::ShiftLeft, Some(Variant_::ShiftLeft)) => {
95                        let value = map.next_value()?;
96                        BitOperationFunction::ShiftLeft(value)
97                    }
98                    (Variant_::BitTest, Some(Variant_::BitTest)) => {
99                        let value = map.next_value()?;
100                        BitOperationFunction::BitTest(value)
101                    }
102                    (Variant_::Unknown(type_), Some(Variant_::Unknown(b))) => {
103                        if type_ == b {
104                            let value = map.next_value()?;
105                            BitOperationFunction::Unknown(Unknown { type_, value })
106                        } else {
107                            return Err(
108                                de::Error::invalid_value(de::Unexpected::Str(&type_), &&*b),
109                            )
110                        }
111                    }
112                    (variant, Some(key)) => {
113                        return Err(
114                            de::Error::invalid_value(
115                                de::Unexpected::Str(key.as_str()),
116                                &variant.as_str(),
117                            ),
118                        );
119                    }
120                    (variant, None) => {
121                        return Err(de::Error::missing_field(variant.as_str()));
122                    }
123                }
124            }
125            Some(UnionField_::Value(variant)) => {
126                let value = match &variant {
127                    Variant_::And => {
128                        let value = map.next_value()?;
129                        BitOperationFunction::And(value)
130                    }
131                    Variant_::Or => {
132                        let value = map.next_value()?;
133                        BitOperationFunction::Or(value)
134                    }
135                    Variant_::Xor => {
136                        let value = map.next_value()?;
137                        BitOperationFunction::Xor(value)
138                    }
139                    Variant_::ShiftRight => {
140                        let value = map.next_value()?;
141                        BitOperationFunction::ShiftRight(value)
142                    }
143                    Variant_::ShiftLeft => {
144                        let value = map.next_value()?;
145                        BitOperationFunction::ShiftLeft(value)
146                    }
147                    Variant_::BitTest => {
148                        let value = map.next_value()?;
149                        BitOperationFunction::BitTest(value)
150                    }
151                    Variant_::Unknown(type_) => {
152                        let value = map.next_value()?;
153                        BitOperationFunction::Unknown(Unknown {
154                            type_: type_.clone(),
155                            value,
156                        })
157                    }
158                };
159                if map.next_key::<UnionTypeField_>()?.is_none() {
160                    return Err(de::Error::missing_field("type"));
161                }
162                let type_variant = map.next_value::<Variant_>()?;
163                if variant != type_variant {
164                    return Err(
165                        de::Error::invalid_value(
166                            de::Unexpected::Str(type_variant.as_str()),
167                            &variant.as_str(),
168                        ),
169                    );
170                }
171                value
172            }
173            None => return Err(de::Error::missing_field("type")),
174        };
175        if map.next_key::<UnionField_<Variant_>>()?.is_some() {
176            return Err(de::Error::invalid_length(3, &"type and value fields"));
177        }
178        Ok(v)
179    }
180}
181#[derive(PartialEq)]
182enum Variant_ {
183    And,
184    Or,
185    Xor,
186    ShiftRight,
187    ShiftLeft,
188    BitTest,
189    Unknown(Box<str>),
190}
191impl Variant_ {
192    fn as_str(&self) -> &'static str {
193        match *self {
194            Variant_::And => "and",
195            Variant_::Or => "or",
196            Variant_::Xor => "xor",
197            Variant_::ShiftRight => "shiftRight",
198            Variant_::ShiftLeft => "shiftLeft",
199            Variant_::BitTest => "bitTest",
200            Variant_::Unknown(_) => "unknown variant",
201        }
202    }
203}
204impl<'de> de::Deserialize<'de> for Variant_ {
205    fn deserialize<D>(d: D) -> Result<Variant_, D::Error>
206    where
207        D: de::Deserializer<'de>,
208    {
209        d.deserialize_str(VariantVisitor_)
210    }
211}
212struct VariantVisitor_;
213impl<'de> de::Visitor<'de> for VariantVisitor_ {
214    type Value = Variant_;
215    fn expecting(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
216        fmt.write_str("string")
217    }
218    fn visit_str<E>(self, value: &str) -> Result<Variant_, E>
219    where
220        E: de::Error,
221    {
222        let v = match value {
223            "and" => Variant_::And,
224            "or" => Variant_::Or,
225            "xor" => Variant_::Xor,
226            "shiftRight" => Variant_::ShiftRight,
227            "shiftLeft" => Variant_::ShiftLeft,
228            "bitTest" => Variant_::BitTest,
229            value => Variant_::Unknown(value.to_string().into_boxed_str()),
230        };
231        Ok(v)
232    }
233}
234///An unknown variant of the BitOperationFunction union.
235#[derive(Debug, Clone, PartialEq, Eq, PartialOrd, Ord, Hash)]
236pub struct Unknown {
237    type_: Box<str>,
238    value: conjure_object::Any,
239}
240impl Unknown {
241    /// Returns the unknown variant's type name.
242    #[inline]
243    pub fn type_(&self) -> &str {
244        &self.type_
245    }
246}