nominal_api/conjure/objects/scout/compute/api/
bit_operation_function.rs1use 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 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#[derive(Debug, Clone, PartialEq, Eq, PartialOrd, Ord, Hash)]
236pub struct Unknown {
237 type_: Box<str>,
238 value: conjure_object::Any,
239}
240impl Unknown {
241 #[inline]
243 pub fn type_(&self) -> &str {
244 &self.type_
245 }
246}