Client Test

Client Test

rev. dfb5149b65b7bcc09edd15b8e071ad43b5ac5943

Files changed:

tmp-codegen-diff/codegen-client-test/json_rpc10/rust-client-codegen/src/protocol_serde/shape_my_union.rs

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

tmp-codegen-diff/codegen-client-test/json_rpc10/rust-client-codegen/src/protocol_serde/shape_no_input_and_no_output.rs

@@ -1,1 +38,56 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* RustType.kt:516 */
    2      3   
#[allow(clippy::unnecessary_wraps)]
           4  +
/* ProtocolParserGenerator.kt:99 */
    3      5   
pub fn de_no_input_and_no_output_http_error(
    4      6   
    _response_status: u16,
    5      7   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
    6      8   
    _response_body: &[u8],
    7      9   
) -> std::result::Result<
    8     10   
    crate::operation::no_input_and_no_output::NoInputAndNoOutputOutput,
    9     11   
    crate::operation::no_input_and_no_output::NoInputAndNoOutputError,
   10     12   
> {
          13  +
    /* RustType.kt:516 */
   11     14   
    #[allow(unused_mut)]
          15  +
    /* ProtocolParserGenerator.kt:106 */
   12     16   
    let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(_response_status, _response_headers, _response_body)
   13     17   
        .map_err(crate::operation::no_input_and_no_output::NoInputAndNoOutputError::unhandled)?;
          18  +
    /* ProtocolParserGenerator.kt:120 */
   14     19   
    let generic = generic_builder.build();
          20  +
    /* ProtocolParserGenerator.kt:185 */
   15     21   
    Err(crate::operation::no_input_and_no_output::NoInputAndNoOutputError::generic(generic))
          22  +
    /* ProtocolParserGenerator.kt:99 */
   16     23   
}
   17     24   
          25  +
/* RustType.kt:516 */
   18     26   
#[allow(clippy::unnecessary_wraps)]
          27  +
/* ProtocolParserGenerator.kt:71 */
   19     28   
pub fn de_no_input_and_no_output_http_response(
   20     29   
    _response_status: u16,
   21     30   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
   22     31   
    _response_body: &[u8],
   23     32   
) -> std::result::Result<
   24     33   
    crate::operation::no_input_and_no_output::NoInputAndNoOutputOutput,
   25     34   
    crate::operation::no_input_and_no_output::NoInputAndNoOutputError,
   26     35   
> {
          36  +
    /* ProtocolParserGenerator.kt:77 */
   27     37   
    Ok({
          38  +
        /* RustType.kt:516 */
   28     39   
        #[allow(unused_mut)]
          40  +
        /* ProtocolParserGenerator.kt:240 */
   29     41   
        let mut output = crate::operation::no_input_and_no_output::builders::NoInputAndNoOutputOutputBuilder::default();
          42  +
        /* ClientBuilderInstantiator.kt:56 */
   30     43   
        output.build()
          44  +
        /* ProtocolParserGenerator.kt:77 */
   31     45   
    })
          46  +
    /* ProtocolParserGenerator.kt:71 */
   32     47   
}
   33     48   
          49  +
/* AwsJson.kt:152 */
   34     50   
pub fn ser_no_input_and_no_output_input(
   35     51   
    _input: &crate::operation::no_input_and_no_output::NoInputAndNoOutputInput,
   36     52   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
          53  +
    /* AwsJson.kt:156 */
   37     54   
    Ok(::aws_smithy_types::body::SdkBody::from("{}"))
          55  +
    /* AwsJson.kt:152 */
   38     56   
}

tmp-codegen-diff/codegen-client-test/json_rpc10/rust-client-codegen/src/protocol_serde/shape_no_input_and_output.rs

@@ -1,1 +34,52 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* RustType.kt:516 */
    2      3   
#[allow(clippy::unnecessary_wraps)]
           4  +
/* ProtocolParserGenerator.kt:99 */
    3      5   
pub fn de_no_input_and_output_http_error(
    4      6   
    _response_status: u16,
    5      7   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
    6      8   
    _response_body: &[u8],
    7      9   
) -> std::result::Result<crate::operation::no_input_and_output::NoInputAndOutputOutput, crate::operation::no_input_and_output::NoInputAndOutputError>
    8     10   
{
          11  +
    /* RustType.kt:516 */
    9     12   
    #[allow(unused_mut)]
          13  +
    /* ProtocolParserGenerator.kt:106 */
   10     14   
    let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(_response_status, _response_headers, _response_body)
   11     15   
        .map_err(crate::operation::no_input_and_output::NoInputAndOutputError::unhandled)?;
          16  +
    /* ProtocolParserGenerator.kt:120 */
   12     17   
    let generic = generic_builder.build();
          18  +
    /* ProtocolParserGenerator.kt:185 */
   13     19   
    Err(crate::operation::no_input_and_output::NoInputAndOutputError::generic(generic))
          20  +
    /* ProtocolParserGenerator.kt:99 */
   14     21   
}
   15     22   
          23  +
/* RustType.kt:516 */
   16     24   
#[allow(clippy::unnecessary_wraps)]
          25  +
/* ProtocolParserGenerator.kt:71 */
   17     26   
pub fn de_no_input_and_output_http_response(
   18     27   
    _response_status: u16,
   19     28   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
   20     29   
    _response_body: &[u8],
   21     30   
) -> std::result::Result<crate::operation::no_input_and_output::NoInputAndOutputOutput, crate::operation::no_input_and_output::NoInputAndOutputError>
   22     31   
{
          32  +
    /* ProtocolParserGenerator.kt:77 */
   23     33   
    Ok({
          34  +
        /* RustType.kt:516 */
   24     35   
        #[allow(unused_mut)]
          36  +
        /* ProtocolParserGenerator.kt:240 */
   25     37   
        let mut output = crate::operation::no_input_and_output::builders::NoInputAndOutputOutputBuilder::default();
          38  +
        /* ClientBuilderInstantiator.kt:56 */
   26     39   
        output.build()
          40  +
        /* ProtocolParserGenerator.kt:77 */
   27     41   
    })
          42  +
    /* ProtocolParserGenerator.kt:71 */
   28     43   
}
   29     44   
          45  +
/* AwsJson.kt:152 */
   30     46   
pub fn ser_no_input_and_output_input(
   31     47   
    _input: &crate::operation::no_input_and_output::NoInputAndOutputInput,
   32     48   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
          49  +
    /* AwsJson.kt:156 */
   33     50   
    Ok(::aws_smithy_types::body::SdkBody::from("{}"))
          51  +
    /* AwsJson.kt:152 */
   34     52   
}

tmp-codegen-diff/codegen-client-test/json_rpc10/rust-client-codegen/src/protocol_serde/shape_operation_with_defaults.rs

@@ -1,1 +215,399 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* RustType.kt:516 */
    2      3   
#[allow(clippy::unnecessary_wraps)]
           4  +
/* ProtocolParserGenerator.kt:99 */
    3      5   
pub fn de_operation_with_defaults_http_error(
    4      6   
    _response_status: u16,
    5      7   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
    6      8   
    _response_body: &[u8],
    7      9   
) -> std::result::Result<
    8     10   
    crate::operation::operation_with_defaults::OperationWithDefaultsOutput,
    9     11   
    crate::operation::operation_with_defaults::OperationWithDefaultsError,
   10     12   
> {
          13  +
    /* RustType.kt:516 */
   11     14   
    #[allow(unused_mut)]
          15  +
    /* ProtocolParserGenerator.kt:106 */
   12     16   
    let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(_response_status, _response_headers, _response_body)
   13     17   
        .map_err(crate::operation::operation_with_defaults::OperationWithDefaultsError::unhandled)?;
          18  +
    /* ProtocolParserGenerator.kt:120 */
   14     19   
    let generic = generic_builder.build();
          20  +
    /* ProtocolParserGenerator.kt:185 */
   15     21   
    Err(crate::operation::operation_with_defaults::OperationWithDefaultsError::generic(generic))
          22  +
    /* ProtocolParserGenerator.kt:99 */
   16     23   
}
   17     24   
          25  +
/* RustType.kt:516 */
   18     26   
#[allow(clippy::unnecessary_wraps)]
          27  +
/* ProtocolParserGenerator.kt:71 */
   19     28   
pub fn de_operation_with_defaults_http_response(
   20     29   
    _response_status: u16,
   21     30   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
   22     31   
    _response_body: &[u8],
   23     32   
) -> std::result::Result<
   24     33   
    crate::operation::operation_with_defaults::OperationWithDefaultsOutput,
   25     34   
    crate::operation::operation_with_defaults::OperationWithDefaultsError,
   26     35   
> {
          36  +
    /* ProtocolParserGenerator.kt:77 */
   27     37   
    Ok({
          38  +
        /* RustType.kt:516 */
   28     39   
        #[allow(unused_mut)]
          40  +
        /* ProtocolParserGenerator.kt:240 */
   29     41   
        let mut output = crate::operation::operation_with_defaults::builders::OperationWithDefaultsOutputBuilder::default();
          42  +
        /* ProtocolParserGenerator.kt:247 */
   30     43   
        output = crate::protocol_serde::shape_operation_with_defaults::de_operation_with_defaults(_response_body, output)
   31     44   
            .map_err(crate::operation::operation_with_defaults::OperationWithDefaultsError::unhandled)?;
          45  +
        /* ClientBuilderInstantiator.kt:56 */
   32     46   
        output.build()
          47  +
        /* ProtocolParserGenerator.kt:77 */
   33     48   
    })
          49  +
    /* ProtocolParserGenerator.kt:71 */
   34     50   
}
   35     51   
          52  +
/* JsonSerializerGenerator.kt:287 */
   36     53   
pub fn ser_operation_with_defaults_input(
   37     54   
    input: &crate::operation::operation_with_defaults::OperationWithDefaultsInput,
   38     55   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
          56  +
    /* JsonSerializerGenerator.kt:291 */
   39     57   
    let mut out = String::new();
          58  +
    /* JsonSerializerGenerator.kt:292 */
   40     59   
    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
          60  +
    /* JsonSerializerGenerator.kt:375 */
   41     61   
    crate::protocol_serde::shape_operation_with_defaults_input::ser_operation_with_defaults_input_input(&mut object, input)?;
          62  +
    /* JsonSerializerGenerator.kt:295 */
   42     63   
    object.finish();
          64  +
    /* JsonSerializerGenerator.kt:296 */
   43     65   
    Ok(::aws_smithy_types::body::SdkBody::from(out))
          66  +
    /* JsonSerializerGenerator.kt:287 */
   44     67   
}
   45     68   
          69  +
/* JsonParserGenerator.kt:148 */
   46     70   
pub(crate) fn de_operation_with_defaults(
   47     71   
    value: &[u8],
   48     72   
    mut builder: crate::operation::operation_with_defaults::builders::OperationWithDefaultsOutputBuilder,
   49     73   
) -> ::std::result::Result<
   50     74   
    crate::operation::operation_with_defaults::builders::OperationWithDefaultsOutputBuilder,
   51     75   
    ::aws_smithy_json::deserialize::error::DeserializeError,
   52     76   
> {
          77  +
    /* JsonParserGenerator.kt:153 */
   53     78   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
   54     79   
    let tokens = &mut tokens_owned;
   55     80   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
          81  +
    /* JsonParserGenerator.kt:684 */
   56     82   
    loop {
          83  +
        /* JsonParserGenerator.kt:685 */
   57     84   
        match tokens.next().transpose()? {
   58         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   59         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
   60         -
                "defaultString" => {
   61         -
                    builder = builder.set_default_string(
   62         -
                        ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   63         -
                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   64         -
                            .transpose()?,
   65         -
                    );
          85  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
          86  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
          87  +
                /* JsonParserGenerator.kt:260 */
          88  +
                match key.to_unescaped()?.as_ref() {
          89  +
                    /* JsonParserGenerator.kt:262 */
          90  +
                    "defaultString" => {
          91  +
                        /* JsonParserGenerator.kt:265 */
          92  +
                        builder = builder.set_default_string(
          93  +
                            /* JsonParserGenerator.kt:354 */
          94  +
                            ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
          95  +
                                .map(|s|
          96  +
                                /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          97  +
                                    /* JsonParserGenerator.kt:348 */u.into_owned()
          98  +
                                /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
          99  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
         100  +
                        );
         101  +
                        /* JsonParserGenerator.kt:262 */
         102  +
                    }
         103  +
                    /* JsonParserGenerator.kt:262 */
         104  +
                    "defaultBoolean" => {
         105  +
                        /* JsonParserGenerator.kt:265 */
         106  +
                        builder = builder.set_default_boolean(
         107  +
                            /* JsonParserGenerator.kt:298 */
         108  +
                            ::aws_smithy_json::deserialize::token::expect_bool_or_null(tokens.next())?, /* JsonParserGenerator.kt:265 */
         109  +
                        );
         110  +
                        /* JsonParserGenerator.kt:262 */
         111  +
                    }
         112  +
                    /* JsonParserGenerator.kt:262 */
         113  +
                    "defaultList" => {
         114  +
                        /* JsonParserGenerator.kt:265 */
         115  +
                        builder = builder.set_default_list(
         116  +
                            /* JsonParserGenerator.kt:451 */
         117  +
                            crate::protocol_serde::shape_test_string_list::de_test_string_list(tokens)?, /* JsonParserGenerator.kt:265 */
         118  +
                        );
         119  +
                        /* JsonParserGenerator.kt:262 */
         120  +
                    }
         121  +
                    /* JsonParserGenerator.kt:262 */
         122  +
                    "defaultDocumentMap" => {
         123  +
                        /* JsonParserGenerator.kt:265 */
         124  +
                        builder = builder.set_default_document_map(
         125  +
                            /* JsonParserGenerator.kt:319 */
         126  +
                            Some(::aws_smithy_json::deserialize::token::expect_document(tokens)?), /* JsonParserGenerator.kt:265 */
         127  +
                        );
         128  +
                        /* JsonParserGenerator.kt:262 */
         129  +
                    }
         130  +
                    /* JsonParserGenerator.kt:262 */
         131  +
                    "defaultDocumentString" => {
         132  +
                        /* JsonParserGenerator.kt:265 */
         133  +
                        builder = builder.set_default_document_string(
         134  +
                            /* JsonParserGenerator.kt:319 */
         135  +
                            Some(::aws_smithy_json::deserialize::token::expect_document(tokens)?), /* JsonParserGenerator.kt:265 */
         136  +
                        );
         137  +
                        /* JsonParserGenerator.kt:262 */
         138  +
                    }
         139  +
                    /* JsonParserGenerator.kt:262 */
         140  +
                    "defaultDocumentBoolean" => {
         141  +
                        /* JsonParserGenerator.kt:265 */
         142  +
                        builder = builder.set_default_document_boolean(
         143  +
                            /* JsonParserGenerator.kt:319 */
         144  +
                            Some(::aws_smithy_json::deserialize::token::expect_document(tokens)?), /* JsonParserGenerator.kt:265 */
         145  +
                        );
         146  +
                        /* JsonParserGenerator.kt:262 */
         147  +
                    }
         148  +
                    /* JsonParserGenerator.kt:262 */
         149  +
                    "defaultDocumentList" => {
         150  +
                        /* JsonParserGenerator.kt:265 */
         151  +
                        builder = builder.set_default_document_list(
         152  +
                            /* JsonParserGenerator.kt:319 */
         153  +
                            Some(::aws_smithy_json::deserialize::token::expect_document(tokens)?), /* JsonParserGenerator.kt:265 */
         154  +
                        );
         155  +
                        /* JsonParserGenerator.kt:262 */
         156  +
                    }
         157  +
                    /* JsonParserGenerator.kt:262 */
         158  +
                    "defaultNullDocument" => {
         159  +
                        /* JsonParserGenerator.kt:265 */
         160  +
                        builder = builder.set_default_null_document(
         161  +
                            /* JsonParserGenerator.kt:319 */
         162  +
                            Some(::aws_smithy_json::deserialize::token::expect_document(tokens)?), /* JsonParserGenerator.kt:265 */
         163  +
                        );
         164  +
                        /* JsonParserGenerator.kt:262 */
         165  +
                    }
         166  +
                    /* JsonParserGenerator.kt:262 */
         167  +
                    "defaultTimestamp" => {
         168  +
                        /* JsonParserGenerator.kt:265 */
         169  +
                        builder = builder.set_default_timestamp(
         170  +
                            /* JsonParserGenerator.kt:384 */
         171  +
                            ::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
         172  +
                                tokens.next(),
         173  +
                                ::aws_smithy_types::date_time::Format::EpochSeconds,
         174  +
                            )?, /* JsonParserGenerator.kt:265 */
         175  +
                        );
         176  +
                        /* JsonParserGenerator.kt:262 */
         177  +
                    }
         178  +
                    /* JsonParserGenerator.kt:262 */
         179  +
                    "defaultBlob" => {
         180  +
                        /* JsonParserGenerator.kt:265 */
         181  +
                        builder = builder.set_default_blob(
         182  +
                            /* JsonParserGenerator.kt:326 */
         183  +
                            ::aws_smithy_json::deserialize::token::expect_blob_or_null(tokens.next())?, /* JsonParserGenerator.kt:265 */
         184  +
                        );
         185  +
                        /* JsonParserGenerator.kt:262 */
         186  +
                    }
         187  +
                    /* JsonParserGenerator.kt:262 */
         188  +
                    "defaultByte" => {
         189  +
                        /* JsonParserGenerator.kt:265 */
         190  +
                        builder = builder.set_default_byte(
         191  +
                            /* JsonParserGenerator.kt:365 */
         192  +
                            ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
         193  +
                                .map(i8::try_from)
         194  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
         195  +
                        );
         196  +
                        /* JsonParserGenerator.kt:262 */
         197  +
                    }
         198  +
                    /* JsonParserGenerator.kt:262 */
         199  +
                    "defaultShort" => {
         200  +
                        /* JsonParserGenerator.kt:265 */
         201  +
                        builder = builder.set_default_short(
         202  +
                            /* JsonParserGenerator.kt:365 */
         203  +
                            ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
         204  +
                                .map(i16::try_from)
         205  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
         206  +
                        );
         207  +
                        /* JsonParserGenerator.kt:262 */
         208  +
                    }
         209  +
                    /* JsonParserGenerator.kt:262 */
         210  +
                    "defaultInteger" => {
         211  +
                        /* JsonParserGenerator.kt:265 */
         212  +
                        builder = builder.set_default_integer(
         213  +
                            /* JsonParserGenerator.kt:365 */
         214  +
                            ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
         215  +
                                .map(i32::try_from)
         216  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
         217  +
                        );
         218  +
                        /* JsonParserGenerator.kt:262 */
         219  +
                    }
         220  +
                    /* JsonParserGenerator.kt:262 */
         221  +
                    "defaultLong" => {
         222  +
                        /* JsonParserGenerator.kt:265 */
         223  +
                        builder = builder.set_default_long(
         224  +
                            /* JsonParserGenerator.kt:365 */
         225  +
                            ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
         226  +
                                .map(i64::try_from)
         227  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
         228  +
                        );
         229  +
                        /* JsonParserGenerator.kt:262 */
         230  +
                    }
         231  +
                    /* JsonParserGenerator.kt:262 */
         232  +
                    "defaultFloat" => {
         233  +
                        /* JsonParserGenerator.kt:265 */
         234  +
                        builder = builder.set_default_float(
         235  +
                            /* JsonParserGenerator.kt:361 */::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?.map(|v| v.to_f32_lossy())
         236  +
                        /* JsonParserGenerator.kt:265 */);
         237  +
                        /* JsonParserGenerator.kt:262 */
         238  +
                    }
         239  +
                    /* JsonParserGenerator.kt:262 */
         240  +
                    "defaultDouble" => {
         241  +
                        /* JsonParserGenerator.kt:265 */
         242  +
                        builder = builder.set_default_double(
         243  +
                            /* JsonParserGenerator.kt:363 */::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?.map(|v| v.to_f64_lossy())
         244  +
                        /* JsonParserGenerator.kt:265 */);
         245  +
                        /* JsonParserGenerator.kt:262 */
         246  +
                    }
         247  +
                    /* JsonParserGenerator.kt:262 */
         248  +
                    "defaultMap" => {
         249  +
                        /* JsonParserGenerator.kt:265 */
         250  +
                        builder = builder.set_default_map(
         251  +
                            /* JsonParserGenerator.kt:509 */
         252  +
                            crate::protocol_serde::shape_test_string_map::de_test_string_map(tokens)?, /* JsonParserGenerator.kt:265 */
         253  +
                        );
         254  +
                        /* JsonParserGenerator.kt:262 */
         255  +
                    }
         256  +
                    /* JsonParserGenerator.kt:262 */
         257  +
                    "defaultEnum" => {
         258  +
                        /* JsonParserGenerator.kt:265 */
         259  +
                        builder = builder.set_default_enum(
         260  +
                            /* JsonParserGenerator.kt:354 */
         261  +
                            ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
         262  +
                                .map(|s|
         263  +
                                /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
         264  +
                                    /* JsonParserGenerator.kt:345 */crate::types::TestEnum::from(u.as_ref())
         265  +
                                /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
         266  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
         267  +
                        );
         268  +
                        /* JsonParserGenerator.kt:262 */
         269  +
                    }
         270  +
                    /* JsonParserGenerator.kt:262 */
         271  +
                    "defaultIntEnum" => {
         272  +
                        /* JsonParserGenerator.kt:265 */
         273  +
                        builder = builder.set_default_int_enum(
         274  +
                            /* JsonParserGenerator.kt:365 */
         275  +
                            ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
         276  +
                                .map(i32::try_from)
         277  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
         278  +
                        );
         279  +
                        /* JsonParserGenerator.kt:262 */
         280  +
                    }
         281  +
                    /* JsonParserGenerator.kt:262 */
         282  +
                    "emptyString" => {
         283  +
                        /* JsonParserGenerator.kt:265 */
         284  +
                        builder = builder.set_empty_string(
         285  +
                            /* JsonParserGenerator.kt:354 */
         286  +
                            ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
         287  +
                                .map(|s|
         288  +
                                /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
         289  +
                                    /* JsonParserGenerator.kt:348 */u.into_owned()
         290  +
                                /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
         291  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
         292  +
                        );
         293  +
                        /* JsonParserGenerator.kt:262 */
         294  +
                    }
         295  +
                    /* JsonParserGenerator.kt:262 */
         296  +
                    "falseBoolean" => {
         297  +
                        /* JsonParserGenerator.kt:265 */
         298  +
                        builder = builder.set_false_boolean(
         299  +
                            /* JsonParserGenerator.kt:298 */
         300  +
                            ::aws_smithy_json::deserialize::token::expect_bool_or_null(tokens.next())?, /* JsonParserGenerator.kt:265 */
         301  +
                        );
         302  +
                        /* JsonParserGenerator.kt:262 */
         303  +
                    }
         304  +
                    /* JsonParserGenerator.kt:262 */
         305  +
                    "emptyBlob" => {
         306  +
                        /* JsonParserGenerator.kt:265 */
         307  +
                        builder = builder.set_empty_blob(
         308  +
                            /* JsonParserGenerator.kt:326 */
         309  +
                            ::aws_smithy_json::deserialize::token::expect_blob_or_null(tokens.next())?, /* JsonParserGenerator.kt:265 */
         310  +
                        );
         311  +
                        /* JsonParserGenerator.kt:262 */
         312  +
                    }
         313  +
                    /* JsonParserGenerator.kt:262 */
         314  +
                    "zeroByte" => {
         315  +
                        /* JsonParserGenerator.kt:265 */
         316  +
                        builder = builder.set_zero_byte(
         317  +
                            /* JsonParserGenerator.kt:365 */
         318  +
                            ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
         319  +
                                .map(i8::try_from)
         320  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
         321  +
                        );
         322  +
                        /* JsonParserGenerator.kt:262 */
         323  +
                    }
         324  +
                    /* JsonParserGenerator.kt:262 */
         325  +
                    "zeroShort" => {
         326  +
                        /* JsonParserGenerator.kt:265 */
         327  +
                        builder = builder.set_zero_short(
         328  +
                            /* JsonParserGenerator.kt:365 */
         329  +
                            ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
         330  +
                                .map(i16::try_from)
         331  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
         332  +
                        );
         333  +
                        /* JsonParserGenerator.kt:262 */
         334  +
                    }
         335  +
                    /* JsonParserGenerator.kt:262 */
         336  +
                    "zeroInteger" => {
         337  +
                        /* JsonParserGenerator.kt:265 */
         338  +
                        builder = builder.set_zero_integer(
         339  +
                            /* JsonParserGenerator.kt:365 */
         340  +
                            ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
         341  +
                                .map(i32::try_from)
         342  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
         343  +
                        );
         344  +
                        /* JsonParserGenerator.kt:262 */
         345  +
                    }
         346  +
                    /* JsonParserGenerator.kt:262 */
         347  +
                    "zeroLong" => {
         348  +
                        /* JsonParserGenerator.kt:265 */
         349  +
                        builder = builder.set_zero_long(
         350  +
                            /* JsonParserGenerator.kt:365 */
         351  +
                            ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
         352  +
                                .map(i64::try_from)
         353  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
         354  +
                        );
         355  +
                        /* JsonParserGenerator.kt:262 */
         356  +
                    }
         357  +
                    /* JsonParserGenerator.kt:262 */
         358  +
                    "zeroFloat" => {
         359  +
                        /* JsonParserGenerator.kt:265 */
         360  +
                        builder = builder.set_zero_float(
         361  +
                            /* JsonParserGenerator.kt:361 */::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?.map(|v| v.to_f32_lossy())
         362  +
                        /* JsonParserGenerator.kt:265 */);
         363  +
                        /* JsonParserGenerator.kt:262 */
         364  +
                    }
         365  +
                    /* JsonParserGenerator.kt:262 */
         366  +
                    "zeroDouble" => {
         367  +
                        /* JsonParserGenerator.kt:265 */
         368  +
                        builder = builder.set_zero_double(
         369  +
                            /* JsonParserGenerator.kt:363 */::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?.map(|v| v.to_f64_lossy())
         370  +
                        /* JsonParserGenerator.kt:265 */);
         371  +
                        /* JsonParserGenerator.kt:262 */
         372  +
                    }
         373  +
                    /* JsonParserGenerator.kt:290 */
         374  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
   66    375   
                }
   67         -
                "defaultBoolean" => {
   68         -
                    builder = builder.set_default_boolean(::aws_smithy_json::deserialize::token::expect_bool_or_null(tokens.next())?);
   69         -
                }
   70         -
                "defaultList" => {
   71         -
                    builder = builder.set_default_list(crate::protocol_serde::shape_test_string_list::de_test_string_list(tokens)?);
   72         -
                }
   73         -
                "defaultDocumentMap" => {
   74         -
                    builder = builder.set_default_document_map(Some(::aws_smithy_json::deserialize::token::expect_document(tokens)?));
   75         -
                }
   76         -
                "defaultDocumentString" => {
   77         -
                    builder = builder.set_default_document_string(Some(::aws_smithy_json::deserialize::token::expect_document(tokens)?));
   78         -
                }
   79         -
                "defaultDocumentBoolean" => {
   80         -
                    builder = builder.set_default_document_boolean(Some(::aws_smithy_json::deserialize::token::expect_document(tokens)?));
   81         -
                }
   82         -
                "defaultDocumentList" => {
   83         -
                    builder = builder.set_default_document_list(Some(::aws_smithy_json::deserialize::token::expect_document(tokens)?));
   84         -
                }
   85         -
                "defaultNullDocument" => {
   86         -
                    builder = builder.set_default_null_document(Some(::aws_smithy_json::deserialize::token::expect_document(tokens)?));
   87         -
                }
   88         -
                "defaultTimestamp" => {
   89         -
                    builder = builder.set_default_timestamp(::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
   90         -
                        tokens.next(),
   91         -
                        ::aws_smithy_types::date_time::Format::EpochSeconds,
   92         -
                    )?);
   93         -
                }
   94         -
                "defaultBlob" => {
   95         -
                    builder = builder.set_default_blob(::aws_smithy_json::deserialize::token::expect_blob_or_null(tokens.next())?);
   96         -
                }
   97         -
                "defaultByte" => {
   98         -
                    builder = builder.set_default_byte(
   99         -
                        ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
  100         -
                            .map(i8::try_from)
  101         -
                            .transpose()?,
  102         -
                    );
  103         -
                }
  104         -
                "defaultShort" => {
  105         -
                    builder = builder.set_default_short(
  106         -
                        ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
  107         -
                            .map(i16::try_from)
  108         -
                            .transpose()?,
  109         -
                    );
  110         -
                }
  111         -
                "defaultInteger" => {
  112         -
                    builder = builder.set_default_integer(
  113         -
                        ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
  114         -
                            .map(i32::try_from)
  115         -
                            .transpose()?,
  116         -
                    );
  117         -
                }
  118         -
                "defaultLong" => {
  119         -
                    builder = builder.set_default_long(
  120         -
                        ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
  121         -
                            .map(i64::try_from)
  122         -
                            .transpose()?,
  123         -
                    );
  124         -
                }
  125         -
                "defaultFloat" => {
  126         -
                    builder = builder
  127         -
                        .set_default_float(::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?.map(|v| v.to_f32_lossy()));
  128         -
                }
  129         -
                "defaultDouble" => {
  130         -
                    builder = builder
  131         -
                        .set_default_double(::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?.map(|v| v.to_f64_lossy()));
  132         -
                }
  133         -
                "defaultMap" => {
  134         -
                    builder = builder.set_default_map(crate::protocol_serde::shape_test_string_map::de_test_string_map(tokens)?);
  135         -
                }
  136         -
                "defaultEnum" => {
  137         -
                    builder = builder.set_default_enum(
  138         -
                        ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
  139         -
                            .map(|s| s.to_unescaped().map(|u| crate::types::TestEnum::from(u.as_ref())))
  140         -
                            .transpose()?,
  141         -
                    );
  142         -
                }
  143         -
                "defaultIntEnum" => {
  144         -
                    builder = builder.set_default_int_enum(
  145         -
                        ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
  146         -
                            .map(i32::try_from)
  147         -
                            .transpose()?,
  148         -
                    );
  149         -
                }
  150         -
                "emptyString" => {
  151         -
                    builder = builder.set_empty_string(
  152         -
                        ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
  153         -
                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
  154         -
                            .transpose()?,
  155         -
                    );
  156         -
                }
  157         -
                "falseBoolean" => {
  158         -
                    builder = builder.set_false_boolean(::aws_smithy_json::deserialize::token::expect_bool_or_null(tokens.next())?);
  159         -
                }
  160         -
                "emptyBlob" => {
  161         -
                    builder = builder.set_empty_blob(::aws_smithy_json::deserialize::token::expect_blob_or_null(tokens.next())?);
  162         -
                }
  163         -
                "zeroByte" => {
  164         -
                    builder = builder.set_zero_byte(
  165         -
                        ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
  166         -
                            .map(i8::try_from)
  167         -
                            .transpose()?,
  168         -
                    );
  169         -
                }
  170         -
                "zeroShort" => {
  171         -
                    builder = builder.set_zero_short(
  172         -
                        ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
  173         -
                            .map(i16::try_from)
  174         -
                            .transpose()?,
  175         -
                    );
  176         -
                }
  177         -
                "zeroInteger" => {
  178         -
                    builder = builder.set_zero_integer(
  179         -
                        ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
  180         -
                            .map(i32::try_from)
  181         -
                            .transpose()?,
  182         -
                    );
  183         -
                }
  184         -
                "zeroLong" => {
  185         -
                    builder = builder.set_zero_long(
  186         -
                        ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
  187         -
                            .map(i64::try_from)
  188         -
                            .transpose()?,
  189         -
                    );
  190         -
                }
  191         -
                "zeroFloat" => {
  192         -
                    builder = builder
  193         -
                        .set_zero_float(::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?.map(|v| v.to_f32_lossy()));
  194         -
                }
  195         -
                "zeroDouble" => {
  196         -
                    builder = builder
  197         -
                        .set_zero_double(::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?.map(|v| v.to_f64_lossy()));
  198         -
                }
  199         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
  200         -
            },
         376  +
                /* JsonParserGenerator.kt:686 */
         377  +
            }
         378  +
            /* JsonParserGenerator.kt:695 */
  201    379   
            other => {
  202    380   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
  203    381   
                    "expected object key or end object, found: {:?}",
  204    382   
                    other
  205    383   
                )))
  206         -
            }
         384  +
            } /* JsonParserGenerator.kt:685 */
  207    385   
        }
         386  +
        /* JsonParserGenerator.kt:684 */
  208    387   
    }
         388  +
    /* JsonParserGenerator.kt:250 */
  209    389   
    if tokens.next().is_some() {
         390  +
        /* JsonParserGenerator.kt:251 */
  210    391   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
  211    392   
            "found more JSON tokens after completing parsing",
  212    393   
        ));
         394  +
        /* JsonParserGenerator.kt:250 */
  213    395   
    }
         396  +
    /* JsonParserGenerator.kt:163 */
  214    397   
    Ok(builder)
         398  +
    /* JsonParserGenerator.kt:148 */
  215    399   
}

tmp-codegen-diff/codegen-client-test/json_rpc10/rust-client-codegen/src/protocol_serde/shape_operation_with_defaults_input.rs

@@ -1,1 +28,49 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_operation_with_defaults_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::operation_with_defaults::OperationWithDefaultsInput,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.defaults {
           9  +
        /* JsonSerializerGenerator.kt:495 */
    7     10   
        #[allow(unused_mut)]
          11  +
        /* JsonSerializerGenerator.kt:496 */
    8     12   
        let mut object_2 = object.key("defaults").start_object();
          13  +
        /* JsonSerializerGenerator.kt:375 */
    9     14   
        crate::protocol_serde::shape_defaults::ser_defaults(&mut object_2, var_1)?;
          15  +
        /* JsonSerializerGenerator.kt:515 */
   10     16   
        object_2.finish();
          17  +
        /* JsonSerializerGenerator.kt:382 */
   11     18   
    }
          19  +
    /* JsonSerializerGenerator.kt:382 */
   12     20   
    if let Some(var_3) = &input.client_optional_defaults {
          21  +
        /* JsonSerializerGenerator.kt:495 */
   13     22   
        #[allow(unused_mut)]
          23  +
        /* JsonSerializerGenerator.kt:496 */
   14     24   
        let mut object_4 = object.key("clientOptionalDefaults").start_object();
          25  +
        /* JsonSerializerGenerator.kt:375 */
   15     26   
        crate::protocol_serde::shape_client_optional_defaults::ser_client_optional_defaults(&mut object_4, var_3)?;
          27  +
        /* JsonSerializerGenerator.kt:515 */
   16     28   
        object_4.finish();
          29  +
        /* JsonSerializerGenerator.kt:382 */
   17     30   
    }
          31  +
    /* JsonSerializerGenerator.kt:382 */
   18     32   
    if let Some(var_5) = &input.top_level_default {
          33  +
        /* JsonSerializerGenerator.kt:423 */
   19     34   
        object.key("topLevelDefault").string(var_5.as_str());
          35  +
        /* JsonSerializerGenerator.kt:382 */
   20     36   
    }
          37  +
    /* JsonSerializerGenerator.kt:382 */
   21     38   
    if let Some(var_6) = &input.other_top_level_default {
          39  +
        /* JsonSerializerGenerator.kt:432 */
   22     40   
        object.key("otherTopLevelDefault").number(
   23     41   
            #[allow(clippy::useless_conversion)]
   24     42   
            ::aws_smithy_types::Number::NegInt((*var_6).into()),
   25     43   
        );
          44  +
        /* JsonSerializerGenerator.kt:382 */
   26     45   
    }
          46  +
    /* JsonSerializerGenerator.kt:372 */
   27     47   
    Ok(())
          48  +
    /* JsonSerializerGenerator.kt:358 */
   28     49   
}

tmp-codegen-diff/codegen-client-test/json_rpc10/rust-client-codegen/src/protocol_serde/shape_operation_with_nested_structure.rs

@@ -1,1 +87,144 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* RustType.kt:516 */
    2      3   
#[allow(clippy::unnecessary_wraps)]
           4  +
/* ProtocolParserGenerator.kt:99 */
    3      5   
pub fn de_operation_with_nested_structure_http_error(
    4      6   
    _response_status: u16,
    5      7   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
    6      8   
    _response_body: &[u8],
    7      9   
) -> std::result::Result<
    8     10   
    crate::operation::operation_with_nested_structure::OperationWithNestedStructureOutput,
    9     11   
    crate::operation::operation_with_nested_structure::OperationWithNestedStructureError,
   10     12   
> {
          13  +
    /* RustType.kt:516 */
   11     14   
    #[allow(unused_mut)]
          15  +
    /* ProtocolParserGenerator.kt:106 */
   12     16   
    let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(_response_status, _response_headers, _response_body)
   13     17   
        .map_err(crate::operation::operation_with_nested_structure::OperationWithNestedStructureError::unhandled)?;
          18  +
    /* ProtocolParserGenerator.kt:120 */
   14     19   
    let generic = generic_builder.build();
          20  +
    /* ProtocolParserGenerator.kt:185 */
   15     21   
    Err(crate::operation::operation_with_nested_structure::OperationWithNestedStructureError::generic(generic))
          22  +
    /* ProtocolParserGenerator.kt:99 */
   16     23   
}
   17     24   
          25  +
/* RustType.kt:516 */
   18     26   
#[allow(clippy::unnecessary_wraps)]
          27  +
/* ProtocolParserGenerator.kt:71 */
   19     28   
pub fn de_operation_with_nested_structure_http_response(
   20     29   
    _response_status: u16,
   21     30   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
   22     31   
    _response_body: &[u8],
   23     32   
) -> std::result::Result<
   24     33   
    crate::operation::operation_with_nested_structure::OperationWithNestedStructureOutput,
   25     34   
    crate::operation::operation_with_nested_structure::OperationWithNestedStructureError,
   26     35   
> {
          36  +
    /* ProtocolParserGenerator.kt:77 */
   27     37   
    Ok({
          38  +
        /* RustType.kt:516 */
   28     39   
        #[allow(unused_mut)]
          40  +
        /* ProtocolParserGenerator.kt:240 */
   29     41   
        let mut output = crate::operation::operation_with_nested_structure::builders::OperationWithNestedStructureOutputBuilder::default();
          42  +
        /* ProtocolParserGenerator.kt:247 */
   30     43   
        output = crate::protocol_serde::shape_operation_with_nested_structure::de_operation_with_nested_structure(_response_body, output)
   31     44   
            .map_err(crate::operation::operation_with_nested_structure::OperationWithNestedStructureError::unhandled)?;
          45  +
        /* ClientBuilderInstantiator.kt:46 */
   32     46   
        crate::serde_util::operation_with_nested_structure_output_output_correct_errors(output)
   33     47   
            .build()
   34     48   
            .map_err(crate::operation::operation_with_nested_structure::OperationWithNestedStructureError::unhandled)?
          49  +
        /* ProtocolParserGenerator.kt:77 */
   35     50   
    })
          51  +
    /* ProtocolParserGenerator.kt:71 */
   36     52   
}
   37     53   
          54  +
/* JsonSerializerGenerator.kt:287 */
   38     55   
pub fn ser_operation_with_nested_structure_input(
   39     56   
    input: &crate::operation::operation_with_nested_structure::OperationWithNestedStructureInput,
   40     57   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
          58  +
    /* JsonSerializerGenerator.kt:291 */
   41     59   
    let mut out = String::new();
          60  +
    /* JsonSerializerGenerator.kt:292 */
   42     61   
    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
          62  +
    /* JsonSerializerGenerator.kt:375 */
   43     63   
    crate::protocol_serde::shape_operation_with_nested_structure_input::ser_operation_with_nested_structure_input_input(&mut object, input)?;
          64  +
    /* JsonSerializerGenerator.kt:295 */
   44     65   
    object.finish();
          66  +
    /* JsonSerializerGenerator.kt:296 */
   45     67   
    Ok(::aws_smithy_types::body::SdkBody::from(out))
          68  +
    /* JsonSerializerGenerator.kt:287 */
   46     69   
}
   47     70   
          71  +
/* JsonParserGenerator.kt:148 */
   48     72   
pub(crate) fn de_operation_with_nested_structure(
   49     73   
    value: &[u8],
   50     74   
    mut builder: crate::operation::operation_with_nested_structure::builders::OperationWithNestedStructureOutputBuilder,
   51     75   
) -> ::std::result::Result<
   52     76   
    crate::operation::operation_with_nested_structure::builders::OperationWithNestedStructureOutputBuilder,
   53     77   
    ::aws_smithy_json::deserialize::error::DeserializeError,
   54     78   
> {
          79  +
    /* JsonParserGenerator.kt:153 */
   55     80   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
   56     81   
    let tokens = &mut tokens_owned;
   57     82   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
          83  +
    /* JsonParserGenerator.kt:684 */
   58     84   
    loop {
          85  +
        /* JsonParserGenerator.kt:685 */
   59     86   
        match tokens.next().transpose()? {
   60         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   61         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
   62         -
                "dialog" => {
   63         -
                    builder = builder.set_dialog(crate::protocol_serde::shape_dialog::de_dialog(tokens)?);
          87  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
          88  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
          89  +
                /* JsonParserGenerator.kt:260 */
          90  +
                match key.to_unescaped()?.as_ref() {
          91  +
                    /* JsonParserGenerator.kt:262 */
          92  +
                    "dialog" => {
          93  +
                        /* JsonParserGenerator.kt:265 */
          94  +
                        builder = builder.set_dialog(
          95  +
                            /* JsonParserGenerator.kt:544 */
          96  +
                            crate::protocol_serde::shape_dialog::de_dialog(tokens)?, /* JsonParserGenerator.kt:265 */
          97  +
                        );
          98  +
                        /* JsonParserGenerator.kt:262 */
          99  +
                    }
         100  +
                    /* JsonParserGenerator.kt:262 */
         101  +
                    "dialogList" => {
         102  +
                        /* JsonParserGenerator.kt:265 */
         103  +
                        builder = builder.set_dialog_list(
         104  +
                            /* JsonParserGenerator.kt:451 */
         105  +
                            crate::protocol_serde::shape_dialog_list::de_dialog_list(tokens)?, /* JsonParserGenerator.kt:265 */
         106  +
                        );
         107  +
                        /* JsonParserGenerator.kt:262 */
         108  +
                    }
         109  +
                    /* JsonParserGenerator.kt:262 */
         110  +
                    "dialogMap" => {
         111  +
                        /* JsonParserGenerator.kt:265 */
         112  +
                        builder = builder.set_dialog_map(
         113  +
                            /* JsonParserGenerator.kt:509 */
         114  +
                            crate::protocol_serde::shape_dialog_map::de_dialog_map(tokens)?, /* JsonParserGenerator.kt:265 */
         115  +
                        );
         116  +
                        /* JsonParserGenerator.kt:262 */
         117  +
                    }
         118  +
                    /* JsonParserGenerator.kt:290 */
         119  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
   64    120   
                }
   65         -
                "dialogList" => {
   66         -
                    builder = builder.set_dialog_list(crate::protocol_serde::shape_dialog_list::de_dialog_list(tokens)?);
   67         -
                }
   68         -
                "dialogMap" => {
   69         -
                    builder = builder.set_dialog_map(crate::protocol_serde::shape_dialog_map::de_dialog_map(tokens)?);
   70         -
                }
   71         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   72         -
            },
         121  +
                /* JsonParserGenerator.kt:686 */
         122  +
            }
         123  +
            /* JsonParserGenerator.kt:695 */
   73    124   
            other => {
   74    125   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   75    126   
                    "expected object key or end object, found: {:?}",
   76    127   
                    other
   77    128   
                )))
   78         -
            }
         129  +
            } /* JsonParserGenerator.kt:685 */
   79    130   
        }
         131  +
        /* JsonParserGenerator.kt:684 */
   80    132   
    }
         133  +
    /* JsonParserGenerator.kt:250 */
   81    134   
    if tokens.next().is_some() {
         135  +
        /* JsonParserGenerator.kt:251 */
   82    136   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   83    137   
            "found more JSON tokens after completing parsing",
   84    138   
        ));
         139  +
        /* JsonParserGenerator.kt:250 */
   85    140   
    }
         141  +
    /* JsonParserGenerator.kt:163 */
   86    142   
    Ok(builder)
         143  +
    /* JsonParserGenerator.kt:148 */
   87    144   
}