1 + | // Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
|
2 + | /* JsonParserGenerator.kt:551 */
|
3 + | pub(crate) fn de_my_union<'a, I>(
|
4 + | tokens: &mut ::std::iter::Peekable<I>,
|
5 + | ) -> ::std::result::Result<
|
6 + | Option<crate::unconstrained::my_union_unconstrained::MyUnionUnconstrained>,
|
7 + | ::aws_smithy_json::deserialize::error::DeserializeError,
|
8 + | >
|
9 + | where
|
10 + | I: Iterator<
|
11 + | Item = Result<
|
12 + | ::aws_smithy_json::deserialize::Token<'a>,
|
13 + | ::aws_smithy_json::deserialize::error::DeserializeError,
|
14 + | >,
|
15 + | >,
|
16 + | {
|
17 + | /* JsonParserGenerator.kt:565 */
|
18 + | let mut variant = None;
|
19 + | /* JsonParserGenerator.kt:567 */
|
20 + | match tokens.next().transpose()? {
|
21 + | /* JsonParserGenerator.kt:568 */
|
22 + | Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => return Ok(None),
|
23 + | Some(::aws_smithy_json::deserialize::Token::StartObject { .. }) => {
|
24 + | /* JsonParserGenerator.kt:684 */
|
25 + | loop {
|
26 + | /* JsonParserGenerator.kt:685 */
|
27 + | match tokens.next().transpose()? {
|
28 + | /* JsonParserGenerator.kt:686 */
|
29 + | Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
|
30 + | Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
|
31 + | /* JsonParserGenerator.kt:576 */
|
32 + | if let ::std::option::Option::Some(::std::result::Result::Ok(
|
33 + | ::aws_smithy_json::deserialize::Token::ValueNull { .. },
|
34 + | )) = tokens.peek()
|
35 + | {
|
36 + | let _ = tokens.next().expect("peek returned a token")?;
|
37 + | continue;
|
38 + | }
|
39 + | /* JsonParserGenerator.kt:585 */
|
40 + | let key = key.to_unescaped()?;
|
41 + | if key == "__type" {
|
42 + | ::aws_smithy_json::deserialize::token::skip_value(tokens)?;
|
43 + | continue;
|
44 + | }
|
45 + | if variant.is_some() {
|
46 + | return Err(
|
47 + | ::aws_smithy_json::deserialize::error::DeserializeError::custom(
|
48 + | "encountered mixed variants in union",
|
49 + | ),
|
50 + | );
|
51 + | }
|
52 + | /* JsonParserGenerator.kt:598 */
|
53 + | variant = match key.as_ref() {
|
54 + | /* JsonParserGenerator.kt:601 */
|
55 + | "stringValue" => {
|
56 + | /* JsonParserGenerator.kt:611 */
|
57 + | Some(crate::unconstrained::my_union_unconstrained::MyUnionUnconstrained::StringValue(
|
58 + | /* JsonParserGenerator.kt:354 */::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?.map(|s|
|
59 + | /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
|
60 + | /* JsonParserGenerator.kt:348 */u.into_owned()
|
61 + | /* JsonParserGenerator.kt:339 */)
|
62 + | /* JsonParserGenerator.kt:354 */).transpose()?
|
63 + | /* JsonParserGenerator.kt:670 */.ok_or_else(|| ::aws_smithy_json::deserialize::error::DeserializeError::custom("value for 'stringValue' cannot be null"))?
|
64 + | /* JsonParserGenerator.kt:611 */))
|
65 + | /* JsonParserGenerator.kt:601 */
|
66 + | }
|
67 + | /* JsonParserGenerator.kt:601 */
|
68 + | "booleanValue" => {
|
69 + | /* JsonParserGenerator.kt:611 */
|
70 + | Some(crate::unconstrained::my_union_unconstrained::MyUnionUnconstrained::BooleanValue(
|
71 + | /* JsonParserGenerator.kt:298 */::aws_smithy_json::deserialize::token::expect_bool_or_null(tokens.next())?
|
72 + | /* JsonParserGenerator.kt:670 */.ok_or_else(|| ::aws_smithy_json::deserialize::error::DeserializeError::custom("value for 'booleanValue' cannot be null"))?
|
73 + | /* JsonParserGenerator.kt:611 */))
|
74 + | /* JsonParserGenerator.kt:601 */
|
75 + | }
|
76 + | /* JsonParserGenerator.kt:601 */
|
77 + | "numberValue" => {
|
78 + | /* JsonParserGenerator.kt:611 */
|
79 + | Some(crate::unconstrained::my_union_unconstrained::MyUnionUnconstrained::NumberValue(
|
80 + | /* JsonParserGenerator.kt:365 */::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
|
81 + | .map(i32::try_from)
|
82 + | .transpose()?
|
83 + | /* JsonParserGenerator.kt:670 */.ok_or_else(|| ::aws_smithy_json::deserialize::error::DeserializeError::custom("value for 'numberValue' cannot be null"))?
|
84 + | /* JsonParserGenerator.kt:611 */))
|
85 + | /* JsonParserGenerator.kt:601 */
|
86 + | }
|
87 + | /* JsonParserGenerator.kt:601 */
|
88 + | "blobValue" => {
|
89 + | /* JsonParserGenerator.kt:611 */
|
90 + | Some(crate::unconstrained::my_union_unconstrained::MyUnionUnconstrained::BlobValue(
|
91 + | /* JsonParserGenerator.kt:326 */::aws_smithy_json::deserialize::token::expect_blob_or_null(tokens.next())?
|
92 + | /* JsonParserGenerator.kt:670 */.ok_or_else(|| ::aws_smithy_json::deserialize::error::DeserializeError::custom("value for 'blobValue' cannot be null"))?
|
93 + | /* JsonParserGenerator.kt:611 */))
|
94 + | /* JsonParserGenerator.kt:601 */
|
95 + | }
|
96 + | /* JsonParserGenerator.kt:601 */
|
97 + | "timestampValue" => {
|
98 + | /* JsonParserGenerator.kt:611 */
|
99 + | Some(crate::unconstrained::my_union_unconstrained::MyUnionUnconstrained::TimestampValue(
|
100 + | /* JsonParserGenerator.kt:384 */::aws_smithy_json::deserialize::token::expect_timestamp_or_null(tokens.next(), ::aws_smithy_types::date_time::Format::EpochSeconds)?
|
101 + | /* JsonParserGenerator.kt:670 */.ok_or_else(|| ::aws_smithy_json::deserialize::error::DeserializeError::custom("value for 'timestampValue' cannot be null"))?
|
102 + | /* JsonParserGenerator.kt:611 */))
|
103 + | /* JsonParserGenerator.kt:601 */
|
104 + | }
|
105 + | /* JsonParserGenerator.kt:601 */
|
106 + | "enumValue" => {
|
107 + | /* JsonParserGenerator.kt:611 */
|
108 + | Some(crate::unconstrained::my_union_unconstrained::MyUnionUnconstrained::EnumValue(
|
109 + | /* JsonParserGenerator.kt:354 */::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?.map(|s|
|
110 + | /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
|
111 + | /* JsonParserGenerator.kt:343 */u.into_owned()
|
112 + | /* JsonParserGenerator.kt:339 */)
|
113 + | /* JsonParserGenerator.kt:354 */).transpose()?
|
114 + | /* JsonParserGenerator.kt:670 */.ok_or_else(|| ::aws_smithy_json::deserialize::error::DeserializeError::custom("value for 'enumValue' cannot be null"))?
|
115 + | /* JsonParserGenerator.kt:611 */))
|
116 + | /* JsonParserGenerator.kt:601 */
|
117 + | }
|
118 + | /* JsonParserGenerator.kt:601 */
|
119 + | "listValue" => {
|
120 + | /* JsonParserGenerator.kt:611 */
|
121 + | Some(crate::unconstrained::my_union_unconstrained::MyUnionUnconstrained::ListValue(
|
122 + | /* JsonParserGenerator.kt:451 */crate::protocol_serde::shape_string_list::de_string_list(tokens)?
|
123 + | /* JsonParserGenerator.kt:670 */.ok_or_else(|| ::aws_smithy_json::deserialize::error::DeserializeError::custom("value for 'listValue' cannot be null"))?
|
124 + | /* JsonParserGenerator.kt:611 */))
|
125 + | /* JsonParserGenerator.kt:601 */
|
126 + | }
|
127 + | /* JsonParserGenerator.kt:601 */
|
128 + | "mapValue" => {
|
129 + | /* JsonParserGenerator.kt:611 */
|
130 + | Some(crate::unconstrained::my_union_unconstrained::MyUnionUnconstrained::MapValue(
|
131 + | /* JsonParserGenerator.kt:509 */crate::protocol_serde::shape_string_map::de_string_map(tokens)?
|
132 + | /* JsonParserGenerator.kt:670 */.ok_or_else(|| ::aws_smithy_json::deserialize::error::DeserializeError::custom("value for 'mapValue' cannot be null"))?
|
133 + | /* JsonParserGenerator.kt:611 */))
|
134 + | /* JsonParserGenerator.kt:601 */
|
135 + | }
|
136 + | /* JsonParserGenerator.kt:601 */
|
137 + | "structureValue" => {
|
138 + | /* JsonParserGenerator.kt:611 */
|
139 + | Some(crate::unconstrained::my_union_unconstrained::MyUnionUnconstrained::StructureValue(
|
140 + | /* JsonParserGenerator.kt:544 */crate::protocol_serde::shape_greeting_struct::de_greeting_struct(tokens)?
|
141 + | /* JsonParserGenerator.kt:670 */.ok_or_else(|| ::aws_smithy_json::deserialize::error::DeserializeError::custom("value for 'structureValue' cannot be null"))?
|
142 + | /* JsonParserGenerator.kt:611 */))
|
143 + | /* JsonParserGenerator.kt:601 */
|
144 + | }
|
145 + | /* JsonParserGenerator.kt:601 */
|
146 + | "renamedStructureValue" => {
|
147 + | /* JsonParserGenerator.kt:611 */
|
148 + | Some(crate::unconstrained::my_union_unconstrained::MyUnionUnconstrained::RenamedStructureValue(
|
149 + | /* JsonParserGenerator.kt:544 */crate::protocol_serde::shape_renamed_greeting::de_renamed_greeting(tokens)?
|
150 + | /* JsonParserGenerator.kt:670 */.ok_or_else(|| ::aws_smithy_json::deserialize::error::DeserializeError::custom("value for 'renamedStructureValue' cannot be null"))?
|
151 + | /* JsonParserGenerator.kt:611 */))
|
152 + | /* JsonParserGenerator.kt:601 */
|
153 + | }
|
154 + | /* JsonParserGenerator.kt:634 */
|
155 + | variant => {
|
156 + | return Err(
|
157 + | ::aws_smithy_json::deserialize::error::DeserializeError::custom(
|
158 + | format!("unexpected union variant: {variant}"),
|
159 + | ),
|
160 + | )
|
161 + | } /* JsonParserGenerator.kt:598 */
|
162 + | };
|
163 + | /* JsonParserGenerator.kt:686 */
|
164 + | }
|
165 + | /* JsonParserGenerator.kt:695 */
|
166 + | other => {
|
167 + | return Err(
|
168 + | ::aws_smithy_json::deserialize::error::DeserializeError::custom(
|
169 + | format!("expected object key or end object, found: {other:?}"),
|
170 + | ),
|
171 + | )
|
172 + | } /* JsonParserGenerator.kt:685 */
|
173 + | }
|
174 + | /* JsonParserGenerator.kt:684 */
|
175 + | }
|
176 + | /* JsonParserGenerator.kt:568 */
|
177 + | }
|
178 + | /* JsonParserGenerator.kt:642 */
|
179 + | _ => {
|
180 + | return Err(
|
181 + | ::aws_smithy_json::deserialize::error::DeserializeError::custom(
|
182 + | "expected start object or null",
|
183 + | ),
|
184 + | )
|
185 + | } /* JsonParserGenerator.kt:567 */
|
186 + | }
|
187 + | /* JsonParserGenerator.kt:649 */
|
188 + | if variant.is_none() {
|
189 + | return Err(
|
190 + | ::aws_smithy_json::deserialize::error::DeserializeError::custom(
|
191 + | "Union did not contain a valid variant.",
|
192 + | ),
|
193 + | );
|
194 + | }
|
195 + | /* JsonParserGenerator.kt:657 */
|
196 + | Ok(variant)
|
197 + | /* JsonParserGenerator.kt:551 */
|
198 + | }
|
199 + |
|
200 + | /* JsonSerializerGenerator.kt:547 */
|
201 + | pub fn ser_my_union(
|
202 + | object_2: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
|
203 + | input: &crate::model::MyUnion,
|
204 + | ) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
|
205 + | /* JsonSerializerGenerator.kt:556 */
|
206 + | match input {
|
207 + | /* JsonSerializerGenerator.kt:564 */
|
208 + | crate::model::MyUnion::StringValue(inner) => {
|
209 + | /* SerializerUtil.kt:42 */
|
210 + | {
|
211 + | /* JsonSerializerGenerator.kt:423 */
|
212 + | object_2.key("stringValue").string(inner.as_str());
|
213 + | /* SerializerUtil.kt:42 */
|
214 + | }
|
215 + | /* JsonSerializerGenerator.kt:564 */
|
216 + | }
|
217 + | /* JsonSerializerGenerator.kt:564 */
|
218 + | crate::model::MyUnion::BooleanValue(inner) => {
|
219 + | /* SerializerUtil.kt:42 */
|
220 + | {
|
221 + | /* JsonSerializerGenerator.kt:424 */
|
222 + | object_2.key("booleanValue").boolean(*inner);
|
223 + | /* SerializerUtil.kt:42 */
|
224 + | }
|
225 + | /* JsonSerializerGenerator.kt:564 */
|
226 + | }
|
227 + | /* JsonSerializerGenerator.kt:564 */
|
228 + | crate::model::MyUnion::NumberValue(inner) => {
|
229 + | /* SerializerUtil.kt:42 */
|
230 + | {
|
231 + | /* JsonSerializerGenerator.kt:432 */
|
232 + | object_2.key("numberValue").number(
|
233 + | #[allow(clippy::useless_conversion)]
|
234 + | ::aws_smithy_types::Number::NegInt((*inner).into()),
|
235 + | );
|
236 + | /* SerializerUtil.kt:42 */
|
237 + | }
|
238 + | /* JsonSerializerGenerator.kt:564 */
|
239 + | }
|
240 + | /* JsonSerializerGenerator.kt:564 */
|
241 + | crate::model::MyUnion::BlobValue(inner) => {
|
242 + | /* SerializerUtil.kt:42 */
|
243 + | {
|
244 + | /* JsonSerializerGenerator.kt:439 */
|
245 + | object_2
|
246 + | .key("blobValue")
|
247 + | .string_unchecked(&::aws_smithy_types::base64::encode(inner));
|
248 + | /* SerializerUtil.kt:42 */
|
249 + | }
|
250 + | /* JsonSerializerGenerator.kt:564 */
|
251 + | }
|
252 + | /* JsonSerializerGenerator.kt:564 */
|
253 + | crate::model::MyUnion::TimestampValue(inner) => {
|
254 + | /* SerializerUtil.kt:42 */
|
255 + | {
|
256 + | /* JsonSerializerGenerator.kt:448 */
|
257 + | object_2
|
258 + | .key("timestampValue")
|
259 + | .date_time(inner, ::aws_smithy_types::date_time::Format::EpochSeconds)?;
|
260 + | /* SerializerUtil.kt:42 */
|
261 + | }
|
262 + | /* JsonSerializerGenerator.kt:564 */
|
263 + | }
|
264 + | /* JsonSerializerGenerator.kt:564 */
|
265 + | crate::model::MyUnion::EnumValue(inner) => {
|
266 + | /* SerializerUtil.kt:42 */
|
267 + | {
|
268 + | /* JsonSerializerGenerator.kt:423 */
|
269 + | object_2.key("enumValue").string(inner.as_str());
|
270 + | /* SerializerUtil.kt:42 */
|
271 + | }
|
272 + | /* JsonSerializerGenerator.kt:564 */
|
273 + | }
|
274 + | /* JsonSerializerGenerator.kt:564 */
|
275 + | crate::model::MyUnion::ListValue(inner) => {
|
276 + | /* SerializerUtil.kt:42 */
|
277 + | {
|
278 + | /* JsonSerializerGenerator.kt:484 */
|
279 + | let mut array_1 = object_2.key("listValue").start_array();
|
280 + | /* JsonSerializerGenerator.kt:524 */
|
281 + | for item_2 in inner {
|
282 + | /* SerializerUtil.kt:42 */
|
283 + | {
|
284 + | /* JsonSerializerGenerator.kt:423 */
|
285 + | array_1.value().string(item_2.as_str());
|
286 + | /* SerializerUtil.kt:42 */
|
287 + | }
|
288 + | /* JsonSerializerGenerator.kt:524 */
|
289 + | }
|
290 + | /* JsonSerializerGenerator.kt:486 */
|
291 + | array_1.finish();
|
292 + | /* SerializerUtil.kt:42 */
|
293 + | }
|
294 + | /* JsonSerializerGenerator.kt:564 */
|
295 + | }
|
296 + | /* JsonSerializerGenerator.kt:564 */
|
297 + | crate::model::MyUnion::MapValue(inner) => {
|
298 + | /* SerializerUtil.kt:42 */
|
299 + | {
|
300 + | /* JsonSerializerGenerator.kt:495 */
|
301 + | #[allow(unused_mut)]
|
302 + | /* JsonSerializerGenerator.kt:496 */
|
303 + | let mut object_3 = object_2.key("mapValue").start_object();
|
304 + | /* JsonSerializerGenerator.kt:537 */
|
305 + | for (key_4, value_5) in inner {
|
306 + | /* SerializerUtil.kt:42 */
|
307 + | {
|
308 + | /* JsonSerializerGenerator.kt:423 */
|
309 + | object_3.key(key_4.as_str()).string(value_5.as_str());
|
310 + | /* SerializerUtil.kt:42 */
|
311 + | }
|
312 + | /* JsonSerializerGenerator.kt:537 */
|
313 + | }
|
314 + | /* JsonSerializerGenerator.kt:515 */
|
315 + | object_3.finish();
|
316 + | /* SerializerUtil.kt:42 */
|
317 + | }
|
318 + | /* JsonSerializerGenerator.kt:564 */
|
319 + | }
|
320 + | /* JsonSerializerGenerator.kt:564 */
|
321 + | crate::model::MyUnion::StructureValue(inner) => {
|
322 + | /* SerializerUtil.kt:42 */
|
323 + | {
|
324 + | /* JsonSerializerGenerator.kt:495 */
|
325 + | #[allow(unused_mut)]
|
326 + | /* JsonSerializerGenerator.kt:496 */
|
327 + | let mut object_6 = object_2.key("structureValue").start_object();
|
328 + | /* JsonSerializerGenerator.kt:375 */
|
329 + | crate::protocol_serde::shape_greeting_struct::ser_greeting_struct(
|
330 + | &mut object_6,
|
331 + | inner,
|
332 + | )?;
|
333 + | /* JsonSerializerGenerator.kt:515 */
|
334 + | object_6.finish();
|
335 + | /* SerializerUtil.kt:42 */
|
336 + | }
|
337 + | /* JsonSerializerGenerator.kt:564 */
|
338 + | }
|
339 + | /* JsonSerializerGenerator.kt:564 */
|
340 + | crate::model::MyUnion::RenamedStructureValue(inner) => {
|
341 + | /* SerializerUtil.kt:42 */
|
342 + | {
|
343 + | /* JsonSerializerGenerator.kt:495 */
|
344 + | #[allow(unused_mut)]
|
345 + | /* JsonSerializerGenerator.kt:496 */
|
346 + | let mut object_7 = object_2.key("renamedStructureValue").start_object();
|
347 + | /* JsonSerializerGenerator.kt:375 */
|
348 + | crate::protocol_serde::shape_renamed_greeting::ser_renamed_greeting(
|
349 + | &mut object_7,
|
350 + | inner,
|
351 + | )?;
|
352 + | /* JsonSerializerGenerator.kt:515 */
|
353 + | object_7.finish();
|
354 + | /* SerializerUtil.kt:42 */
|
355 + | }
|
356 + | /* JsonSerializerGenerator.kt:564 */
|
357 + | }
|
358 + | /* JsonSerializerGenerator.kt:556 */
|
359 + | }
|
360 + | /* JsonSerializerGenerator.kt:576 */
|
361 + | Ok(())
|
362 + | /* JsonSerializerGenerator.kt:547 */
|
363 + | }
|