Client Test

Client Test

rev. dfb5149b65b7bcc09edd15b8e071ad43b5ac5943

Files changed:

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_table_in_use_exception.rs

@@ -1,1 +36,59 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonParserGenerator.kt:148 */
    2      3   
pub(crate) fn de_table_in_use_exception_json_err(
    3      4   
    value: &[u8],
    4      5   
    mut builder: crate::types::error::builders::TableInUseErrorBuilder,
    5      6   
) -> ::std::result::Result<crate::types::error::builders::TableInUseErrorBuilder, ::aws_smithy_json::deserialize::error::DeserializeError> {
           7  +
    /* JsonParserGenerator.kt:153 */
    6      8   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
    7      9   
    let tokens = &mut tokens_owned;
    8     10   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
          11  +
    /* JsonParserGenerator.kt:684 */
    9     12   
    loop {
          13  +
        /* JsonParserGenerator.kt:685 */
   10     14   
        match tokens.next().transpose()? {
   11         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   12         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
   13         -
                "message" => {
   14         -
                    builder = builder.set_message(
   15         -
                        ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   16         -
                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   17         -
                            .transpose()?,
   18         -
                    );
          15  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
          16  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
          17  +
                /* JsonParserGenerator.kt:260 */
          18  +
                match key.to_unescaped()?.as_ref() {
          19  +
                    /* JsonParserGenerator.kt:262 */
          20  +
                    "message" => {
          21  +
                        /* JsonParserGenerator.kt:265 */
          22  +
                        builder = builder.set_message(
          23  +
                            /* JsonParserGenerator.kt:354 */
          24  +
                            ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
          25  +
                                .map(|s|
          26  +
                                /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          27  +
                                    /* JsonParserGenerator.kt:348 */u.into_owned()
          28  +
                                /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
          29  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
          30  +
                        );
          31  +
                        /* JsonParserGenerator.kt:262 */
          32  +
                    }
          33  +
                    /* JsonParserGenerator.kt:290 */
          34  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
   19     35   
                }
   20         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   21         -
            },
          36  +
                /* JsonParserGenerator.kt:686 */
          37  +
            }
          38  +
            /* JsonParserGenerator.kt:695 */
   22     39   
            other => {
   23     40   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   24     41   
                    "expected object key or end object, found: {:?}",
   25     42   
                    other
   26     43   
                )))
   27         -
            }
          44  +
            } /* JsonParserGenerator.kt:685 */
   28     45   
        }
          46  +
        /* JsonParserGenerator.kt:684 */
   29     47   
    }
          48  +
    /* JsonParserGenerator.kt:250 */
   30     49   
    if tokens.next().is_some() {
          50  +
        /* JsonParserGenerator.kt:251 */
   31     51   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   32     52   
            "found more JSON tokens after completing parsing",
   33     53   
        ));
          54  +
        /* JsonParserGenerator.kt:250 */
   34     55   
    }
          56  +
    /* JsonParserGenerator.kt:163 */
   35     57   
    Ok(builder)
          58  +
    /* JsonParserGenerator.kt:148 */
   36     59   
}

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_table_name_list.rs

@@ -1,1 +34,59 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonParserGenerator.kt:398 */
    2      3   
pub(crate) fn de_table_name_list<'a, I>(
    3      4   
    tokens: &mut ::std::iter::Peekable<I>,
    4      5   
) -> ::std::result::Result<Option<::std::vec::Vec<::std::string::String>>, ::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:712 */
    8     10   
    match tokens.next().transpose()? {
    9         -
        Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
          11  +
        /* JsonParserGenerator.kt:713 */ Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
   10     12   
        Some(::aws_smithy_json::deserialize::Token::StartArray { .. }) => {
          13  +
            /* JsonParserGenerator.kt:407 */
   11     14   
            let mut items = Vec::new();
          15  +
            /* JsonParserGenerator.kt:408 */
   12     16   
            loop {
          17  +
                /* JsonParserGenerator.kt:409 */
   13     18   
                match tokens.peek() {
          19  +
                    /* JsonParserGenerator.kt:410 */
   14     20   
                    Some(Ok(::aws_smithy_json::deserialize::Token::EndArray { .. })) => {
          21  +
                        /* JsonParserGenerator.kt:411 */
   15     22   
                        tokens.next().transpose().unwrap();
   16     23   
                        break;
          24  +
                        /* JsonParserGenerator.kt:410 */
   17     25   
                    }
          26  +
                    /* JsonParserGenerator.kt:413 */
   18     27   
                    _ => {
   19         -
                        let value = ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   20         -
                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   21         -
                            .transpose()?;
          28  +
                        /* JsonParserGenerator.kt:419 */
          29  +
                        let value =
          30  +
                            /* JsonParserGenerator.kt:354 */::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?.map(|s|
          31  +
                                /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          32  +
                                    /* JsonParserGenerator.kt:348 */u.into_owned()
          33  +
                                /* JsonParserGenerator.kt:339 */)
          34  +
                            /* JsonParserGenerator.kt:354 */).transpose()?
          35  +
                        /* JsonParserGenerator.kt:419 */;
          36  +
                        /* JsonParserGenerator.kt:422 */
   22     37   
                        if let Some(value) = value {
   23     38   
                            items.push(value);
   24     39   
                        }
   25         -
                    }
          40  +
                        /* JsonParserGenerator.kt:413 */
          41  +
                    } /* JsonParserGenerator.kt:409 */
   26     42   
                }
          43  +
                /* JsonParserGenerator.kt:408 */
   27     44   
            }
          45  +
            /* JsonParserGenerator.kt:446 */
   28     46   
            Ok(Some(items))
          47  +
            /* JsonParserGenerator.kt:713 */
   29     48   
        }
   30         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   31         -
            "expected start array or null",
   32         -
        )),
          49  +
        /* JsonParserGenerator.kt:722 */
          50  +
        _ => {
          51  +
            /* JsonParserGenerator.kt:723 */
          52  +
            Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
          53  +
                "expected start array or null",
          54  +
            ))
          55  +
            /* JsonParserGenerator.kt:722 */
          56  +
        } /* JsonParserGenerator.kt:712 */
   33     57   
    }
          58  +
    /* JsonParserGenerator.kt:398 */
   34     59   
}

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_table_not_found_exception.rs

@@ -1,1 +36,59 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonParserGenerator.kt:148 */
    2      3   
pub(crate) fn de_table_not_found_exception_json_err(
    3      4   
    value: &[u8],
    4      5   
    mut builder: crate::types::error::builders::TableNotFoundErrorBuilder,
    5      6   
) -> ::std::result::Result<crate::types::error::builders::TableNotFoundErrorBuilder, ::aws_smithy_json::deserialize::error::DeserializeError> {
           7  +
    /* JsonParserGenerator.kt:153 */
    6      8   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
    7      9   
    let tokens = &mut tokens_owned;
    8     10   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
          11  +
    /* JsonParserGenerator.kt:684 */
    9     12   
    loop {
          13  +
        /* JsonParserGenerator.kt:685 */
   10     14   
        match tokens.next().transpose()? {
   11         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   12         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
   13         -
                "message" => {
   14         -
                    builder = builder.set_message(
   15         -
                        ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   16         -
                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   17         -
                            .transpose()?,
   18         -
                    );
          15  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
          16  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
          17  +
                /* JsonParserGenerator.kt:260 */
          18  +
                match key.to_unescaped()?.as_ref() {
          19  +
                    /* JsonParserGenerator.kt:262 */
          20  +
                    "message" => {
          21  +
                        /* JsonParserGenerator.kt:265 */
          22  +
                        builder = builder.set_message(
          23  +
                            /* JsonParserGenerator.kt:354 */
          24  +
                            ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
          25  +
                                .map(|s|
          26  +
                                /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          27  +
                                    /* JsonParserGenerator.kt:348 */u.into_owned()
          28  +
                                /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
          29  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
          30  +
                        );
          31  +
                        /* JsonParserGenerator.kt:262 */
          32  +
                    }
          33  +
                    /* JsonParserGenerator.kt:290 */
          34  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
   19     35   
                }
   20         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   21         -
            },
          36  +
                /* JsonParserGenerator.kt:686 */
          37  +
            }
          38  +
            /* JsonParserGenerator.kt:695 */
   22     39   
            other => {
   23     40   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   24     41   
                    "expected object key or end object, found: {:?}",
   25     42   
                    other
   26     43   
                )))
   27         -
            }
          44  +
            } /* JsonParserGenerator.kt:685 */
   28     45   
        }
          46  +
        /* JsonParserGenerator.kt:684 */
   29     47   
    }
          48  +
    /* JsonParserGenerator.kt:250 */
   30     49   
    if tokens.next().is_some() {
          50  +
        /* JsonParserGenerator.kt:251 */
   31     51   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   32     52   
            "found more JSON tokens after completing parsing",
   33     53   
        ));
          54  +
        /* JsonParserGenerator.kt:250 */
   34     55   
    }
          56  +
    /* JsonParserGenerator.kt:163 */
   35     57   
    Ok(builder)
          58  +
    /* JsonParserGenerator.kt:148 */
   36     59   
}

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_tag.rs

@@ -1,1 +62,106 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_tag(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::types::Tag,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* SerializerUtil.kt:42 */
    6      8   
    {
           9  +
        /* JsonSerializerGenerator.kt:423 */
    7     10   
        object.key("Key").string(input.key.as_str());
          11  +
        /* SerializerUtil.kt:42 */
    8     12   
    }
          13  +
    /* SerializerUtil.kt:42 */
    9     14   
    {
          15  +
        /* JsonSerializerGenerator.kt:423 */
   10     16   
        object.key("Value").string(input.value.as_str());
          17  +
        /* SerializerUtil.kt:42 */
   11     18   
    }
          19  +
    /* JsonSerializerGenerator.kt:372 */
   12     20   
    Ok(())
          21  +
    /* JsonSerializerGenerator.kt:358 */
   13     22   
}
   14     23   
          24  +
/* JsonParserGenerator.kt:516 */
   15     25   
pub(crate) fn de_tag<'a, I>(
   16     26   
    tokens: &mut ::std::iter::Peekable<I>,
   17     27   
) -> ::std::result::Result<Option<crate::types::Tag>, ::aws_smithy_json::deserialize::error::DeserializeError>
   18     28   
where
   19     29   
    I: Iterator<Item = Result<::aws_smithy_json::deserialize::Token<'a>, ::aws_smithy_json::deserialize::error::DeserializeError>>,
   20     30   
{
          31  +
    /* JsonParserGenerator.kt:712 */
   21     32   
    match tokens.next().transpose()? {
   22         -
        Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
          33  +
        /* JsonParserGenerator.kt:713 */ Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
   23     34   
        Some(::aws_smithy_json::deserialize::Token::StartObject { .. }) => {
          35  +
            /* RustType.kt:516 */
   24     36   
            #[allow(unused_mut)]
          37  +
            /* JsonParserGenerator.kt:526 */
   25     38   
            let mut builder = crate::types::builders::TagBuilder::default();
          39  +
            /* JsonParserGenerator.kt:684 */
   26     40   
            loop {
          41  +
                /* JsonParserGenerator.kt:685 */
   27     42   
                match tokens.next().transpose()? {
   28         -
                    Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   29         -
                    Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
   30         -
                        "Key" => {
   31         -
                            builder = builder.set_key(
   32         -
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   33         -
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   34         -
                                    .transpose()?,
   35         -
                            );
          43  +
                    /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
          44  +
                    Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
          45  +
                        /* JsonParserGenerator.kt:260 */
          46  +
                        match key.to_unescaped()?.as_ref() {
          47  +
                            /* JsonParserGenerator.kt:262 */
          48  +
                            "Key" => {
          49  +
                                /* JsonParserGenerator.kt:265 */
          50  +
                                builder = builder.set_key(
          51  +
                                    /* JsonParserGenerator.kt:354 */
          52  +
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
          53  +
                                        .map(|s|
          54  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          55  +
                                            /* JsonParserGenerator.kt:348 */u.into_owned()
          56  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
          57  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
          58  +
                                );
          59  +
                                /* JsonParserGenerator.kt:262 */
          60  +
                            }
          61  +
                            /* JsonParserGenerator.kt:262 */
          62  +
                            "Value" => {
          63  +
                                /* JsonParserGenerator.kt:265 */
          64  +
                                builder = builder.set_value(
          65  +
                                    /* JsonParserGenerator.kt:354 */
          66  +
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
          67  +
                                        .map(|s|
          68  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          69  +
                                            /* JsonParserGenerator.kt:348 */u.into_owned()
          70  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
          71  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
          72  +
                                );
          73  +
                                /* JsonParserGenerator.kt:262 */
          74  +
                            }
          75  +
                            /* JsonParserGenerator.kt:290 */
          76  +
                            _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
   36     77   
                        }
   37         -
                        "Value" => {
   38         -
                            builder = builder.set_value(
   39         -
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   40         -
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   41         -
                                    .transpose()?,
   42         -
                            );
   43         -
                        }
   44         -
                        _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   45         -
                    },
          78  +
                        /* JsonParserGenerator.kt:686 */
          79  +
                    }
          80  +
                    /* JsonParserGenerator.kt:695 */
   46     81   
                    other => {
   47     82   
                        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   48     83   
                            "expected object key or end object, found: {:?}",
   49     84   
                            other
   50     85   
                        )))
   51         -
                    }
          86  +
                    } /* JsonParserGenerator.kt:685 */
   52     87   
                }
          88  +
                /* JsonParserGenerator.kt:684 */
   53     89   
            }
          90  +
            /* JsonParserGenerator.kt:540 */
   54     91   
            Ok(Some(crate::serde_util::tag_correct_errors(builder).build().map_err(|err| {
   55     92   
                ::aws_smithy_json::deserialize::error::DeserializeError::custom_source("Response was invalid", err)
   56     93   
            })?))
          94  +
            /* JsonParserGenerator.kt:713 */
   57     95   
        }
   58         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   59         -
            "expected start object or null",
   60         -
        )),
          96  +
        /* JsonParserGenerator.kt:722 */
          97  +
        _ => {
          98  +
            /* JsonParserGenerator.kt:723 */
          99  +
            Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
         100  +
                "expected start object or null",
         101  +
            ))
         102  +
            /* JsonParserGenerator.kt:722 */
         103  +
        } /* JsonParserGenerator.kt:712 */
   61    104   
    }
         105  +
    /* JsonParserGenerator.kt:516 */
   62    106   
}

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_tag_list.rs

@@ -1,1 +32,55 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonParserGenerator.kt:398 */
    2      3   
pub(crate) fn de_tag_list<'a, I>(
    3      4   
    tokens: &mut ::std::iter::Peekable<I>,
    4      5   
) -> ::std::result::Result<Option<::std::vec::Vec<crate::types::Tag>>, ::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:712 */
    8     10   
    match tokens.next().transpose()? {
    9         -
        Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
          11  +
        /* JsonParserGenerator.kt:713 */ Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
   10     12   
        Some(::aws_smithy_json::deserialize::Token::StartArray { .. }) => {
          13  +
            /* JsonParserGenerator.kt:407 */
   11     14   
            let mut items = Vec::new();
          15  +
            /* JsonParserGenerator.kt:408 */
   12     16   
            loop {
          17  +
                /* JsonParserGenerator.kt:409 */
   13     18   
                match tokens.peek() {
          19  +
                    /* JsonParserGenerator.kt:410 */
   14     20   
                    Some(Ok(::aws_smithy_json::deserialize::Token::EndArray { .. })) => {
          21  +
                        /* JsonParserGenerator.kt:411 */
   15     22   
                        tokens.next().transpose().unwrap();
   16     23   
                        break;
          24  +
                        /* JsonParserGenerator.kt:410 */
   17     25   
                    }
          26  +
                    /* JsonParserGenerator.kt:413 */
   18     27   
                    _ => {
   19         -
                        let value = crate::protocol_serde::shape_tag::de_tag(tokens)?;
          28  +
                        /* JsonParserGenerator.kt:419 */
          29  +
                        let value =
          30  +
                            /* JsonParserGenerator.kt:544 */crate::protocol_serde::shape_tag::de_tag(tokens)?
          31  +
                        /* JsonParserGenerator.kt:419 */;
          32  +
                        /* JsonParserGenerator.kt:422 */
   20     33   
                        if let Some(value) = value {
   21     34   
                            items.push(value);
   22     35   
                        }
   23         -
                    }
          36  +
                        /* JsonParserGenerator.kt:413 */
          37  +
                    } /* JsonParserGenerator.kt:409 */
   24     38   
                }
          39  +
                /* JsonParserGenerator.kt:408 */
   25     40   
            }
          41  +
            /* JsonParserGenerator.kt:446 */
   26     42   
            Ok(Some(items))
          43  +
            /* JsonParserGenerator.kt:713 */
   27     44   
        }
   28         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   29         -
            "expected start array or null",
   30         -
        )),
          45  +
        /* JsonParserGenerator.kt:722 */
          46  +
        _ => {
          47  +
            /* JsonParserGenerator.kt:723 */
          48  +
            Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
          49  +
                "expected start array or null",
          50  +
            ))
          51  +
            /* JsonParserGenerator.kt:722 */
          52  +
        } /* JsonParserGenerator.kt:712 */
   31     53   
    }
          54  +
    /* JsonParserGenerator.kt:398 */
   32     55   
}

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_tag_resource.rs

@@ -1,1 +119,173 @@
    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_tag_resource_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::tag_resource::TagResourceOutput, crate::operation::tag_resource::TagResourceError> {
          10  +
    /* RustType.kt:516 */
    8     11   
    #[allow(unused_mut)]
          12  +
    /* ProtocolParserGenerator.kt:106 */
    9     13   
    let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(_response_status, _response_headers, _response_body)
   10     14   
        .map_err(crate::operation::tag_resource::TagResourceError::unhandled)?;
          15  +
    /* ProtocolParserGenerator.kt:120 */
   11     16   
    let generic = generic_builder.build();
          17  +
    /* ProtocolParserGenerator.kt:122 */
   12     18   
    let error_code = match generic.code() {
   13     19   
        Some(code) => code,
   14     20   
        None => return Err(crate::operation::tag_resource::TagResourceError::unhandled(generic)),
   15     21   
    };
   16     22   
   17     23   
    let _error_message = generic.message().map(|msg| msg.to_owned());
          24  +
    /* ProtocolParserGenerator.kt:133 */
   18     25   
    Err(match error_code {
          26  +
        /* ProtocolParserGenerator.kt:139 */
   19     27   
        "InternalServerError" => crate::operation::tag_resource::TagResourceError::InternalServerError({
          28  +
            /* RustType.kt:516 */
   20     29   
            #[allow(unused_mut)]
   21         -
            let mut tmp = {
   22         -
                #[allow(unused_mut)]
   23         -
                let mut output = crate::types::error::builders::InternalServerErrorBuilder::default();
   24         -
                output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output)
   25         -
                    .map_err(crate::operation::tag_resource::TagResourceError::unhandled)?;
   26         -
                let output = output.meta(generic);
   27         -
                output.build()
   28         -
            };
          30  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          31  +
                /* ProtocolParserGenerator.kt:146 */ {
          32  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          33  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::InternalServerErrorBuilder::default();
          34  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output).map_err(crate::operation::tag_resource::TagResourceError::unhandled)?;
          35  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          36  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
          37  +
                /* ProtocolParserGenerator.kt:146 */}
          38  +
            /* ProtocolParserGenerator.kt:145 */;
          39  +
            /* ProtocolParserGenerator.kt:170 */
   29     40   
            if tmp.message.is_none() {
   30     41   
                tmp.message = _error_message;
   31     42   
            }
          43  +
            /* ProtocolParserGenerator.kt:179 */
   32     44   
            tmp
          45  +
            /* ProtocolParserGenerator.kt:139 */
   33     46   
        }),
          47  +
        /* ProtocolParserGenerator.kt:139 */
   34     48   
        "InvalidEndpointException" => crate::operation::tag_resource::TagResourceError::InvalidEndpointError({
          49  +
            /* RustType.kt:516 */
   35     50   
            #[allow(unused_mut)]
   36         -
            let mut tmp = {
   37         -
                #[allow(unused_mut)]
   38         -
                let mut output = crate::types::error::builders::InvalidEndpointErrorBuilder::default();
   39         -
                output = crate::protocol_serde::shape_invalid_endpoint_exception::de_invalid_endpoint_exception_json_err(_response_body, output)
   40         -
                    .map_err(crate::operation::tag_resource::TagResourceError::unhandled)?;
   41         -
                let output = output.meta(generic);
   42         -
                output.build()
   43         -
            };
          51  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          52  +
                /* ProtocolParserGenerator.kt:146 */ {
          53  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          54  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::InvalidEndpointErrorBuilder::default();
          55  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_invalid_endpoint_exception::de_invalid_endpoint_exception_json_err(_response_body, output).map_err(crate::operation::tag_resource::TagResourceError::unhandled)?;
          56  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          57  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
          58  +
                /* ProtocolParserGenerator.kt:146 */}
          59  +
            /* ProtocolParserGenerator.kt:145 */;
          60  +
            /* ProtocolParserGenerator.kt:170 */
   44     61   
            if tmp.message.is_none() {
   45     62   
                tmp.message = _error_message;
   46     63   
            }
          64  +
            /* ProtocolParserGenerator.kt:179 */
   47     65   
            tmp
          66  +
            /* ProtocolParserGenerator.kt:139 */
   48     67   
        }),
          68  +
        /* ProtocolParserGenerator.kt:139 */
   49     69   
        "LimitExceededException" => crate::operation::tag_resource::TagResourceError::LimitExceededError({
          70  +
            /* RustType.kt:516 */
   50     71   
            #[allow(unused_mut)]
   51         -
            let mut tmp = {
   52         -
                #[allow(unused_mut)]
   53         -
                let mut output = crate::types::error::builders::LimitExceededErrorBuilder::default();
   54         -
                output = crate::protocol_serde::shape_limit_exceeded_exception::de_limit_exceeded_exception_json_err(_response_body, output)
   55         -
                    .map_err(crate::operation::tag_resource::TagResourceError::unhandled)?;
   56         -
                let output = output.meta(generic);
   57         -
                output.build()
   58         -
            };
          72  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          73  +
                /* ProtocolParserGenerator.kt:146 */ {
          74  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          75  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::LimitExceededErrorBuilder::default();
          76  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_limit_exceeded_exception::de_limit_exceeded_exception_json_err(_response_body, output).map_err(crate::operation::tag_resource::TagResourceError::unhandled)?;
          77  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          78  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
          79  +
                /* ProtocolParserGenerator.kt:146 */}
          80  +
            /* ProtocolParserGenerator.kt:145 */;
          81  +
            /* ProtocolParserGenerator.kt:170 */
   59     82   
            if tmp.message.is_none() {
   60     83   
                tmp.message = _error_message;
   61     84   
            }
          85  +
            /* ProtocolParserGenerator.kt:179 */
   62     86   
            tmp
          87  +
            /* ProtocolParserGenerator.kt:139 */
   63     88   
        }),
          89  +
        /* ProtocolParserGenerator.kt:139 */
   64     90   
        "ResourceInUseException" => crate::operation::tag_resource::TagResourceError::ResourceInUseError({
          91  +
            /* RustType.kt:516 */
   65     92   
            #[allow(unused_mut)]
   66         -
            let mut tmp = {
   67         -
                #[allow(unused_mut)]
   68         -
                let mut output = crate::types::error::builders::ResourceInUseErrorBuilder::default();
   69         -
                output = crate::protocol_serde::shape_resource_in_use_exception::de_resource_in_use_exception_json_err(_response_body, output)
   70         -
                    .map_err(crate::operation::tag_resource::TagResourceError::unhandled)?;
   71         -
                let output = output.meta(generic);
   72         -
                output.build()
   73         -
            };
          93  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          94  +
                /* ProtocolParserGenerator.kt:146 */ {
          95  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          96  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::ResourceInUseErrorBuilder::default();
          97  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_resource_in_use_exception::de_resource_in_use_exception_json_err(_response_body, output).map_err(crate::operation::tag_resource::TagResourceError::unhandled)?;
          98  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          99  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
         100  +
                /* ProtocolParserGenerator.kt:146 */}
         101  +
            /* ProtocolParserGenerator.kt:145 */;
         102  +
            /* ProtocolParserGenerator.kt:170 */
   74    103   
            if tmp.message.is_none() {
   75    104   
                tmp.message = _error_message;
   76    105   
            }
         106  +
            /* ProtocolParserGenerator.kt:179 */
   77    107   
            tmp
         108  +
            /* ProtocolParserGenerator.kt:139 */
   78    109   
        }),
         110  +
        /* ProtocolParserGenerator.kt:139 */
   79    111   
        "ResourceNotFoundException" => crate::operation::tag_resource::TagResourceError::ResourceNotFoundError({
         112  +
            /* RustType.kt:516 */
   80    113   
            #[allow(unused_mut)]
   81         -
            let mut tmp = {
   82         -
                #[allow(unused_mut)]
   83         -
                let mut output = crate::types::error::builders::ResourceNotFoundErrorBuilder::default();
   84         -
                output = crate::protocol_serde::shape_resource_not_found_exception::de_resource_not_found_exception_json_err(_response_body, output)
   85         -
                    .map_err(crate::operation::tag_resource::TagResourceError::unhandled)?;
   86         -
                let output = output.meta(generic);
   87         -
                output.build()
   88         -
            };
         114  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
         115  +
                /* ProtocolParserGenerator.kt:146 */ {
         116  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
         117  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::ResourceNotFoundErrorBuilder::default();
         118  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_resource_not_found_exception::de_resource_not_found_exception_json_err(_response_body, output).map_err(crate::operation::tag_resource::TagResourceError::unhandled)?;
         119  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
         120  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
         121  +
                /* ProtocolParserGenerator.kt:146 */}
         122  +
            /* ProtocolParserGenerator.kt:145 */;
         123  +
            /* ProtocolParserGenerator.kt:170 */
   89    124   
            if tmp.message.is_none() {
   90    125   
                tmp.message = _error_message;
   91    126   
            }
         127  +
            /* ProtocolParserGenerator.kt:179 */
   92    128   
            tmp
         129  +
            /* ProtocolParserGenerator.kt:139 */
   93    130   
        }),
   94         -
        _ => crate::operation::tag_resource::TagResourceError::generic(generic),
         131  +
        /* ProtocolParserGenerator.kt:182 */
         132  +
        _ => crate::operation::tag_resource::TagResourceError::generic(generic), /* ProtocolParserGenerator.kt:133 */
   95    133   
    })
         134  +
    /* ProtocolParserGenerator.kt:99 */
   96    135   
}
   97    136   
         137  +
/* RustType.kt:516 */
   98    138   
#[allow(clippy::unnecessary_wraps)]
         139  +
/* ProtocolParserGenerator.kt:71 */
   99    140   
pub fn de_tag_resource_http_response(
  100    141   
    _response_status: u16,
  101    142   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
  102    143   
    _response_body: &[u8],
  103    144   
) -> std::result::Result<crate::operation::tag_resource::TagResourceOutput, crate::operation::tag_resource::TagResourceError> {
         145  +
    /* ProtocolParserGenerator.kt:77 */
  104    146   
    Ok({
         147  +
        /* RustType.kt:516 */
  105    148   
        #[allow(unused_mut)]
         149  +
        /* ProtocolParserGenerator.kt:240 */
  106    150   
        let mut output = crate::operation::tag_resource::builders::TagResourceOutputBuilder::default();
         151  +
        /* ClientBuilderInstantiator.kt:56 */
  107    152   
        output.build()
         153  +
        /* ProtocolParserGenerator.kt:77 */
  108    154   
    })
         155  +
    /* ProtocolParserGenerator.kt:71 */
  109    156   
}
  110    157   
         158  +
/* JsonSerializerGenerator.kt:287 */
  111    159   
pub fn ser_tag_resource_input(
  112    160   
    input: &crate::operation::tag_resource::TagResourceInput,
  113    161   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
         162  +
    /* JsonSerializerGenerator.kt:291 */
  114    163   
    let mut out = String::new();
         164  +
    /* JsonSerializerGenerator.kt:292 */
  115    165   
    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
         166  +
    /* JsonSerializerGenerator.kt:375 */
  116    167   
    crate::protocol_serde::shape_tag_resource_input::ser_tag_resource_input_input(&mut object, input)?;
         168  +
    /* JsonSerializerGenerator.kt:295 */
  117    169   
    object.finish();
         170  +
    /* JsonSerializerGenerator.kt:296 */
  118    171   
    Ok(::aws_smithy_types::body::SdkBody::from(out))
         172  +
    /* JsonSerializerGenerator.kt:287 */
  119    173   
}

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_tag_resource_input.rs

@@ -1,1 +22,40 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_tag_resource_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::tag_resource::TagResourceInput,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.resource_arn {
           9  +
        /* JsonSerializerGenerator.kt:423 */
    7     10   
        object.key("ResourceArn").string(var_1.as_str());
          11  +
        /* JsonSerializerGenerator.kt:382 */
    8     12   
    }
          13  +
    /* JsonSerializerGenerator.kt:382 */
    9     14   
    if let Some(var_2) = &input.tags {
          15  +
        /* JsonSerializerGenerator.kt:484 */
   10     16   
        let mut array_3 = object.key("Tags").start_array();
          17  +
        /* JsonSerializerGenerator.kt:524 */
   11     18   
        for item_4 in var_2 {
          19  +
            /* SerializerUtil.kt:42 */
   12     20   
            {
          21  +
                /* JsonSerializerGenerator.kt:495 */
   13     22   
                #[allow(unused_mut)]
          23  +
                /* JsonSerializerGenerator.kt:496 */
   14     24   
                let mut object_5 = array_3.value().start_object();
          25  +
                /* JsonSerializerGenerator.kt:375 */
   15     26   
                crate::protocol_serde::shape_tag::ser_tag(&mut object_5, item_4)?;
          27  +
                /* JsonSerializerGenerator.kt:515 */
   16     28   
                object_5.finish();
          29  +
                /* SerializerUtil.kt:42 */
   17     30   
            }
          31  +
            /* JsonSerializerGenerator.kt:524 */
   18     32   
        }
          33  +
        /* JsonSerializerGenerator.kt:486 */
   19     34   
        array_3.finish();
          35  +
        /* JsonSerializerGenerator.kt:382 */
   20     36   
    }
          37  +
    /* JsonSerializerGenerator.kt:372 */
   21     38   
    Ok(())
          39  +
    /* JsonSerializerGenerator.kt:358 */
   22     40   
}

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_time_to_live_description.rs

@@ -1,1 +47,82 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonParserGenerator.kt:516 */
    2      3   
pub(crate) fn de_time_to_live_description<'a, I>(
    3      4   
    tokens: &mut ::std::iter::Peekable<I>,
    4      5   
) -> ::std::result::Result<Option<crate::types::TimeToLiveDescription>, ::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:712 */
    8     10   
    match tokens.next().transpose()? {
    9         -
        Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
          11  +
        /* JsonParserGenerator.kt:713 */ Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
   10     12   
        Some(::aws_smithy_json::deserialize::Token::StartObject { .. }) => {
          13  +
            /* RustType.kt:516 */
   11     14   
            #[allow(unused_mut)]
          15  +
            /* JsonParserGenerator.kt:526 */
   12     16   
            let mut builder = crate::types::builders::TimeToLiveDescriptionBuilder::default();
          17  +
            /* JsonParserGenerator.kt:684 */
   13     18   
            loop {
          19  +
                /* JsonParserGenerator.kt:685 */
   14     20   
                match tokens.next().transpose()? {
   15         -
                    Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   16         -
                    Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
   17         -
                        "TimeToLiveStatus" => {
   18         -
                            builder = builder.set_time_to_live_status(
   19         -
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   20         -
                                    .map(|s| s.to_unescaped().map(|u| crate::types::TimeToLiveStatus::from(u.as_ref())))
   21         -
                                    .transpose()?,
   22         -
                            );
          21  +
                    /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
          22  +
                    Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
          23  +
                        /* JsonParserGenerator.kt:260 */
          24  +
                        match key.to_unescaped()?.as_ref() {
          25  +
                            /* JsonParserGenerator.kt:262 */
          26  +
                            "TimeToLiveStatus" => {
          27  +
                                /* JsonParserGenerator.kt:265 */
          28  +
                                builder = builder.set_time_to_live_status(
          29  +
                                    /* JsonParserGenerator.kt:354 */
          30  +
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
          31  +
                                        .map(|s|
          32  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          33  +
                                            /* JsonParserGenerator.kt:345 */crate::types::TimeToLiveStatus::from(u.as_ref())
          34  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
          35  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
          36  +
                                );
          37  +
                                /* JsonParserGenerator.kt:262 */
          38  +
                            }
          39  +
                            /* JsonParserGenerator.kt:262 */
          40  +
                            "AttributeName" => {
          41  +
                                /* JsonParserGenerator.kt:265 */
          42  +
                                builder = builder.set_attribute_name(
          43  +
                                    /* JsonParserGenerator.kt:354 */
          44  +
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
          45  +
                                        .map(|s|
          46  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          47  +
                                            /* JsonParserGenerator.kt:348 */u.into_owned()
          48  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
          49  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
          50  +
                                );
          51  +
                                /* JsonParserGenerator.kt:262 */
          52  +
                            }
          53  +
                            /* JsonParserGenerator.kt:290 */
          54  +
                            _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
   23     55   
                        }
   24         -
                        "AttributeName" => {
   25         -
                            builder = builder.set_attribute_name(
   26         -
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   27         -
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   28         -
                                    .transpose()?,
   29         -
                            );
   30         -
                        }
   31         -
                        _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   32         -
                    },
          56  +
                        /* JsonParserGenerator.kt:686 */
          57  +
                    }
          58  +
                    /* JsonParserGenerator.kt:695 */
   33     59   
                    other => {
   34     60   
                        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   35     61   
                            "expected object key or end object, found: {:?}",
   36     62   
                            other
   37     63   
                        )))
   38         -
                    }
          64  +
                    } /* JsonParserGenerator.kt:685 */
   39     65   
                }
          66  +
                /* JsonParserGenerator.kt:684 */
   40     67   
            }
          68  +
            /* JsonParserGenerator.kt:540 */
   41     69   
            Ok(Some(builder.build()))
          70  +
            /* JsonParserGenerator.kt:713 */
   42     71   
        }
   43         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   44         -
            "expected start object or null",
   45         -
        )),
          72  +
        /* JsonParserGenerator.kt:722 */
          73  +
        _ => {
          74  +
            /* JsonParserGenerator.kt:723 */
          75  +
            Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
          76  +
                "expected start object or null",
          77  +
            ))
          78  +
            /* JsonParserGenerator.kt:722 */
          79  +
        } /* JsonParserGenerator.kt:712 */
   46     80   
    }
          81  +
    /* JsonParserGenerator.kt:516 */
   47     82   
}

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_time_to_live_specification.rs

@@ -1,1 +60,103 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonParserGenerator.kt:516 */
    2      3   
pub(crate) fn de_time_to_live_specification<'a, I>(
    3      4   
    tokens: &mut ::std::iter::Peekable<I>,
    4      5   
) -> ::std::result::Result<Option<crate::types::TimeToLiveSpecification>, ::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:712 */
    8     10   
    match tokens.next().transpose()? {
    9         -
        Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
          11  +
        /* JsonParserGenerator.kt:713 */ Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
   10     12   
        Some(::aws_smithy_json::deserialize::Token::StartObject { .. }) => {
          13  +
            /* RustType.kt:516 */
   11     14   
            #[allow(unused_mut)]
          15  +
            /* JsonParserGenerator.kt:526 */
   12     16   
            let mut builder = crate::types::builders::TimeToLiveSpecificationBuilder::default();
          17  +
            /* JsonParserGenerator.kt:684 */
   13     18   
            loop {
          19  +
                /* JsonParserGenerator.kt:685 */
   14     20   
                match tokens.next().transpose()? {
   15         -
                    Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   16         -
                    Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
   17         -
                        "Enabled" => {
   18         -
                            builder = builder.set_enabled(::aws_smithy_json::deserialize::token::expect_bool_or_null(tokens.next())?);
          21  +
                    /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
          22  +
                    Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
          23  +
                        /* JsonParserGenerator.kt:260 */
          24  +
                        match key.to_unescaped()?.as_ref() {
          25  +
                            /* JsonParserGenerator.kt:262 */
          26  +
                            "Enabled" => {
          27  +
                                /* JsonParserGenerator.kt:265 */
          28  +
                                builder = builder.set_enabled(
          29  +
                                    /* JsonParserGenerator.kt:298 */
          30  +
                                    ::aws_smithy_json::deserialize::token::expect_bool_or_null(tokens.next())?, /* JsonParserGenerator.kt:265 */
          31  +
                                );
          32  +
                                /* JsonParserGenerator.kt:262 */
          33  +
                            }
          34  +
                            /* JsonParserGenerator.kt:262 */
          35  +
                            "AttributeName" => {
          36  +
                                /* JsonParserGenerator.kt:265 */
          37  +
                                builder = builder.set_attribute_name(
          38  +
                                    /* JsonParserGenerator.kt:354 */
          39  +
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
          40  +
                                        .map(|s|
          41  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          42  +
                                            /* JsonParserGenerator.kt:348 */u.into_owned()
          43  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
          44  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
          45  +
                                );
          46  +
                                /* JsonParserGenerator.kt:262 */
          47  +
                            }
          48  +
                            /* JsonParserGenerator.kt:290 */
          49  +
                            _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
   19     50   
                        }
   20         -
                        "AttributeName" => {
   21         -
                            builder = builder.set_attribute_name(
   22         -
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   23         -
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   24         -
                                    .transpose()?,
   25         -
                            );
   26         -
                        }
   27         -
                        _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   28         -
                    },
          51  +
                        /* JsonParserGenerator.kt:686 */
          52  +
                    }
          53  +
                    /* JsonParserGenerator.kt:695 */
   29     54   
                    other => {
   30     55   
                        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   31     56   
                            "expected object key or end object, found: {:?}",
   32     57   
                            other
   33     58   
                        )))
   34         -
                    }
          59  +
                    } /* JsonParserGenerator.kt:685 */
   35     60   
                }
          61  +
                /* JsonParserGenerator.kt:684 */
   36     62   
            }
          63  +
            /* JsonParserGenerator.kt:540 */
   37     64   
            Ok(Some(
   38     65   
                crate::serde_util::time_to_live_specification_correct_errors(builder)
   39     66   
                    .build()
   40     67   
                    .map_err(|err| ::aws_smithy_json::deserialize::error::DeserializeError::custom_source("Response was invalid", err))?,
   41     68   
            ))
          69  +
            /* JsonParserGenerator.kt:713 */
   42     70   
        }
   43         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   44         -
            "expected start object or null",
   45         -
        )),
          71  +
        /* JsonParserGenerator.kt:722 */
          72  +
        _ => {
          73  +
            /* JsonParserGenerator.kt:723 */
          74  +
            Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
          75  +
                "expected start object or null",
          76  +
            ))
          77  +
            /* JsonParserGenerator.kt:722 */
          78  +
        } /* JsonParserGenerator.kt:712 */
   46     79   
    }
          80  +
    /* JsonParserGenerator.kt:516 */
   47     81   
}
   48     82   
          83  +
/* JsonSerializerGenerator.kt:358 */
   49     84   
pub fn ser_time_to_live_specification(
   50     85   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
   51     86   
    input: &crate::types::TimeToLiveSpecification,
   52     87   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
          88  +
    /* SerializerUtil.kt:42 */
   53     89   
    {
          90  +
        /* JsonSerializerGenerator.kt:424 */
   54     91   
        object.key("Enabled").boolean(input.enabled);
          92  +
        /* SerializerUtil.kt:42 */
   55     93   
    }
          94  +
    /* SerializerUtil.kt:42 */
   56     95   
    {
          96  +
        /* JsonSerializerGenerator.kt:423 */
   57     97   
        object.key("AttributeName").string(input.attribute_name.as_str());
          98  +
        /* SerializerUtil.kt:42 */
   58     99   
    }
         100  +
    /* JsonSerializerGenerator.kt:372 */
   59    101   
    Ok(())
         102  +
    /* JsonSerializerGenerator.kt:358 */
   60    103   
}

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_transact_get_item.rs

@@ -1,1 +13,22 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_transact_get_item(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::types::TransactGetItem,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* SerializerUtil.kt:42 */
    6      8   
    {
           9  +
        /* JsonSerializerGenerator.kt:495 */
    7     10   
        #[allow(unused_mut)]
          11  +
        /* JsonSerializerGenerator.kt:496 */
    8     12   
        let mut object_1 = object.key("Get").start_object();
          13  +
        /* JsonSerializerGenerator.kt:375 */
    9     14   
        crate::protocol_serde::shape_get::ser_get(&mut object_1, &input.get)?;
          15  +
        /* JsonSerializerGenerator.kt:515 */
   10     16   
        object_1.finish();
          17  +
        /* SerializerUtil.kt:42 */
   11     18   
    }
          19  +
    /* JsonSerializerGenerator.kt:372 */
   12     20   
    Ok(())
          21  +
    /* JsonSerializerGenerator.kt:358 */
   13     22   
}

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_transact_get_items.rs

@@ -1,1 +178,264 @@
    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_transact_get_items_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::transact_get_items::TransactGetItemsOutput, crate::operation::transact_get_items::TransactGetItemsError> {
          10  +
    /* RustType.kt:516 */
    8     11   
    #[allow(unused_mut)]
          12  +
    /* ProtocolParserGenerator.kt:106 */
    9     13   
    let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(_response_status, _response_headers, _response_body)
   10     14   
        .map_err(crate::operation::transact_get_items::TransactGetItemsError::unhandled)?;
          15  +
    /* ProtocolParserGenerator.kt:120 */
   11     16   
    let generic = generic_builder.build();
          17  +
    /* ProtocolParserGenerator.kt:122 */
   12     18   
    let error_code = match generic.code() {
   13     19   
        Some(code) => code,
   14     20   
        None => return Err(crate::operation::transact_get_items::TransactGetItemsError::unhandled(generic)),
   15     21   
    };
   16     22   
   17     23   
    let _error_message = generic.message().map(|msg| msg.to_owned());
          24  +
    /* ProtocolParserGenerator.kt:133 */
   18     25   
    Err(match error_code {
          26  +
        /* ProtocolParserGenerator.kt:139 */
   19     27   
        "InternalServerError" => crate::operation::transact_get_items::TransactGetItemsError::InternalServerError({
          28  +
            /* RustType.kt:516 */
   20     29   
            #[allow(unused_mut)]
   21         -
            let mut tmp = {
   22         -
                #[allow(unused_mut)]
   23         -
                let mut output = crate::types::error::builders::InternalServerErrorBuilder::default();
   24         -
                output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output)
   25         -
                    .map_err(crate::operation::transact_get_items::TransactGetItemsError::unhandled)?;
   26         -
                let output = output.meta(generic);
   27         -
                output.build()
   28         -
            };
          30  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          31  +
                /* ProtocolParserGenerator.kt:146 */ {
          32  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          33  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::InternalServerErrorBuilder::default();
          34  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output).map_err(crate::operation::transact_get_items::TransactGetItemsError::unhandled)?;
          35  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          36  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
          37  +
                /* ProtocolParserGenerator.kt:146 */}
          38  +
            /* ProtocolParserGenerator.kt:145 */;
          39  +
            /* ProtocolParserGenerator.kt:170 */
   29     40   
            if tmp.message.is_none() {
   30     41   
                tmp.message = _error_message;
   31     42   
            }
          43  +
            /* ProtocolParserGenerator.kt:179 */
   32     44   
            tmp
          45  +
            /* ProtocolParserGenerator.kt:139 */
   33     46   
        }),
          47  +
        /* ProtocolParserGenerator.kt:139 */
   34     48   
        "InvalidEndpointException" => crate::operation::transact_get_items::TransactGetItemsError::InvalidEndpointError({
          49  +
            /* RustType.kt:516 */
   35     50   
            #[allow(unused_mut)]
   36         -
            let mut tmp = {
   37         -
                #[allow(unused_mut)]
   38         -
                let mut output = crate::types::error::builders::InvalidEndpointErrorBuilder::default();
   39         -
                output = crate::protocol_serde::shape_invalid_endpoint_exception::de_invalid_endpoint_exception_json_err(_response_body, output)
   40         -
                    .map_err(crate::operation::transact_get_items::TransactGetItemsError::unhandled)?;
   41         -
                let output = output.meta(generic);
   42         -
                output.build()
   43         -
            };
          51  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          52  +
                /* ProtocolParserGenerator.kt:146 */ {
          53  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          54  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::InvalidEndpointErrorBuilder::default();
          55  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_invalid_endpoint_exception::de_invalid_endpoint_exception_json_err(_response_body, output).map_err(crate::operation::transact_get_items::TransactGetItemsError::unhandled)?;
          56  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          57  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
          58  +
                /* ProtocolParserGenerator.kt:146 */}
          59  +
            /* ProtocolParserGenerator.kt:145 */;
          60  +
            /* ProtocolParserGenerator.kt:170 */
   44     61   
            if tmp.message.is_none() {
   45     62   
                tmp.message = _error_message;
   46     63   
            }
          64  +
            /* ProtocolParserGenerator.kt:179 */
   47     65   
            tmp
          66  +
            /* ProtocolParserGenerator.kt:139 */
   48     67   
        }),
          68  +
        /* ProtocolParserGenerator.kt:139 */
   49     69   
        "ProvisionedThroughputExceededException" => {
   50     70   
            crate::operation::transact_get_items::TransactGetItemsError::ProvisionedThroughputExceededError({
          71  +
                /* RustType.kt:516 */
   51     72   
                #[allow(unused_mut)]
   52         -
                let mut tmp = {
   53         -
                    #[allow(unused_mut)]
   54         -
                    let mut output = crate::types::error::builders::ProvisionedThroughputExceededErrorBuilder::default();
   55         -
                    output = crate::protocol_serde::shape_provisioned_throughput_exceeded_exception::de_provisioned_throughput_exceeded_exception_json_err(_response_body, output).map_err(crate::operation::transact_get_items::TransactGetItemsError::unhandled)?;
   56         -
                    let output = output.meta(generic);
   57         -
                    output.build()
   58         -
                };
          73  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          74  +
                /* ProtocolParserGenerator.kt:146 */ {
          75  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          76  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::ProvisionedThroughputExceededErrorBuilder::default();
          77  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_provisioned_throughput_exceeded_exception::de_provisioned_throughput_exceeded_exception_json_err(_response_body, output).map_err(crate::operation::transact_get_items::TransactGetItemsError::unhandled)?;
          78  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          79  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
          80  +
                /* ProtocolParserGenerator.kt:146 */}
          81  +
            /* ProtocolParserGenerator.kt:145 */;
          82  +
                /* ProtocolParserGenerator.kt:170 */
   59     83   
                if tmp.message.is_none() {
   60     84   
                    tmp.message = _error_message;
   61     85   
                }
          86  +
                /* ProtocolParserGenerator.kt:179 */
   62     87   
                tmp
          88  +
                /* ProtocolParserGenerator.kt:139 */
   63     89   
            })
   64     90   
        }
          91  +
        /* ProtocolParserGenerator.kt:139 */
   65     92   
        "RequestLimitExceeded" => crate::operation::transact_get_items::TransactGetItemsError::RequestLimitExceeded({
          93  +
            /* RustType.kt:516 */
   66     94   
            #[allow(unused_mut)]
   67         -
            let mut tmp = {
   68         -
                #[allow(unused_mut)]
   69         -
                let mut output = crate::types::error::builders::RequestLimitExceededBuilder::default();
   70         -
                output = crate::protocol_serde::shape_request_limit_exceeded::de_request_limit_exceeded_json_err(_response_body, output)
   71         -
                    .map_err(crate::operation::transact_get_items::TransactGetItemsError::unhandled)?;
   72         -
                let output = output.meta(generic);
   73         -
                output.build()
   74         -
            };
          95  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          96  +
                /* ProtocolParserGenerator.kt:146 */ {
          97  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          98  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::RequestLimitExceededBuilder::default();
          99  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_request_limit_exceeded::de_request_limit_exceeded_json_err(_response_body, output).map_err(crate::operation::transact_get_items::TransactGetItemsError::unhandled)?;
         100  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
         101  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
         102  +
                /* ProtocolParserGenerator.kt:146 */}
         103  +
            /* ProtocolParserGenerator.kt:145 */;
         104  +
            /* ProtocolParserGenerator.kt:170 */
   75    105   
            if tmp.message.is_none() {
   76    106   
                tmp.message = _error_message;
   77    107   
            }
         108  +
            /* ProtocolParserGenerator.kt:179 */
   78    109   
            tmp
         110  +
            /* ProtocolParserGenerator.kt:139 */
   79    111   
        }),
         112  +
        /* ProtocolParserGenerator.kt:139 */
   80    113   
        "ResourceNotFoundException" => crate::operation::transact_get_items::TransactGetItemsError::ResourceNotFoundError({
         114  +
            /* RustType.kt:516 */
   81    115   
            #[allow(unused_mut)]
   82         -
            let mut tmp = {
   83         -
                #[allow(unused_mut)]
   84         -
                let mut output = crate::types::error::builders::ResourceNotFoundErrorBuilder::default();
   85         -
                output = crate::protocol_serde::shape_resource_not_found_exception::de_resource_not_found_exception_json_err(_response_body, output)
   86         -
                    .map_err(crate::operation::transact_get_items::TransactGetItemsError::unhandled)?;
   87         -
                let output = output.meta(generic);
   88         -
                output.build()
   89         -
            };
         116  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
         117  +
                /* ProtocolParserGenerator.kt:146 */ {
         118  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
         119  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::ResourceNotFoundErrorBuilder::default();
         120  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_resource_not_found_exception::de_resource_not_found_exception_json_err(_response_body, output).map_err(crate::operation::transact_get_items::TransactGetItemsError::unhandled)?;
         121  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
         122  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
         123  +
                /* ProtocolParserGenerator.kt:146 */}
         124  +
            /* ProtocolParserGenerator.kt:145 */;
         125  +
            /* ProtocolParserGenerator.kt:170 */
   90    126   
            if tmp.message.is_none() {
   91    127   
                tmp.message = _error_message;
   92    128   
            }
         129  +
            /* ProtocolParserGenerator.kt:179 */
   93    130   
            tmp
         131  +
            /* ProtocolParserGenerator.kt:139 */
   94    132   
        }),
         133  +
        /* ProtocolParserGenerator.kt:139 */
   95    134   
        "TransactionCanceledException" => crate::operation::transact_get_items::TransactGetItemsError::TransactionCanceledError({
         135  +
            /* RustType.kt:516 */
   96    136   
            #[allow(unused_mut)]
   97         -
            let mut tmp = {
   98         -
                #[allow(unused_mut)]
   99         -
                let mut output = crate::types::error::builders::TransactionCanceledErrorBuilder::default();
  100         -
                output =
  101         -
                    crate::protocol_serde::shape_transaction_canceled_exception::de_transaction_canceled_exception_json_err(_response_body, output)
  102         -
                        .map_err(crate::operation::transact_get_items::TransactGetItemsError::unhandled)?;
  103         -
                let output = output.meta(generic);
  104         -
                output.build()
  105         -
            };
         137  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
         138  +
                /* ProtocolParserGenerator.kt:146 */ {
         139  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
         140  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::TransactionCanceledErrorBuilder::default();
         141  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_transaction_canceled_exception::de_transaction_canceled_exception_json_err(_response_body, output).map_err(crate::operation::transact_get_items::TransactGetItemsError::unhandled)?;
         142  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
         143  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
         144  +
                /* ProtocolParserGenerator.kt:146 */}
         145  +
            /* ProtocolParserGenerator.kt:145 */;
         146  +
            /* ProtocolParserGenerator.kt:170 */
  106    147   
            if tmp.message.is_none() {
  107    148   
                tmp.message = _error_message;
  108    149   
            }
         150  +
            /* ProtocolParserGenerator.kt:179 */
  109    151   
            tmp
         152  +
            /* ProtocolParserGenerator.kt:139 */
  110    153   
        }),
  111         -
        _ => crate::operation::transact_get_items::TransactGetItemsError::generic(generic),
         154  +
        /* ProtocolParserGenerator.kt:182 */
         155  +
        _ => crate::operation::transact_get_items::TransactGetItemsError::generic(generic), /* ProtocolParserGenerator.kt:133 */
  112    156   
    })
         157  +
    /* ProtocolParserGenerator.kt:99 */
  113    158   
}
  114    159   
         160  +
/* RustType.kt:516 */
  115    161   
#[allow(clippy::unnecessary_wraps)]
         162  +
/* ProtocolParserGenerator.kt:71 */
  116    163   
pub fn de_transact_get_items_http_response(
  117    164   
    _response_status: u16,
  118    165   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
  119    166   
    _response_body: &[u8],
  120    167   
) -> std::result::Result<crate::operation::transact_get_items::TransactGetItemsOutput, crate::operation::transact_get_items::TransactGetItemsError> {
         168  +
    /* ProtocolParserGenerator.kt:77 */
  121    169   
    Ok({
         170  +
        /* RustType.kt:516 */
  122    171   
        #[allow(unused_mut)]
         172  +
        /* ProtocolParserGenerator.kt:240 */
  123    173   
        let mut output = crate::operation::transact_get_items::builders::TransactGetItemsOutputBuilder::default();
         174  +
        /* ProtocolParserGenerator.kt:247 */
  124    175   
        output = crate::protocol_serde::shape_transact_get_items::de_transact_get_items(_response_body, output)
  125    176   
            .map_err(crate::operation::transact_get_items::TransactGetItemsError::unhandled)?;
         177  +
        /* ClientBuilderInstantiator.kt:56 */
  126    178   
        output.build()
         179  +
        /* ProtocolParserGenerator.kt:77 */
  127    180   
    })
         181  +
    /* ProtocolParserGenerator.kt:71 */
  128    182   
}
  129    183   
         184  +
/* JsonSerializerGenerator.kt:287 */
  130    185   
pub fn ser_transact_get_items_input(
  131    186   
    input: &crate::operation::transact_get_items::TransactGetItemsInput,
  132    187   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
         188  +
    /* JsonSerializerGenerator.kt:291 */
  133    189   
    let mut out = String::new();
         190  +
    /* JsonSerializerGenerator.kt:292 */
  134    191   
    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
         192  +
    /* JsonSerializerGenerator.kt:375 */
  135    193   
    crate::protocol_serde::shape_transact_get_items_input::ser_transact_get_items_input_input(&mut object, input)?;
         194  +
    /* JsonSerializerGenerator.kt:295 */
  136    195   
    object.finish();
         196  +
    /* JsonSerializerGenerator.kt:296 */
  137    197   
    Ok(::aws_smithy_types::body::SdkBody::from(out))
         198  +
    /* JsonSerializerGenerator.kt:287 */
  138    199   
}
  139    200   
         201  +
/* JsonParserGenerator.kt:148 */
  140    202   
pub(crate) fn de_transact_get_items(
  141    203   
    value: &[u8],
  142    204   
    mut builder: crate::operation::transact_get_items::builders::TransactGetItemsOutputBuilder,
  143    205   
) -> ::std::result::Result<
  144    206   
    crate::operation::transact_get_items::builders::TransactGetItemsOutputBuilder,
  145    207   
    ::aws_smithy_json::deserialize::error::DeserializeError,
  146    208   
> {
         209  +
    /* JsonParserGenerator.kt:153 */
  147    210   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
  148    211   
    let tokens = &mut tokens_owned;
  149    212   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
         213  +
    /* JsonParserGenerator.kt:684 */
  150    214   
    loop {
         215  +
        /* JsonParserGenerator.kt:685 */
  151    216   
        match tokens.next().transpose()? {
  152         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
  153         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
  154         -
                "ConsumedCapacity" => {
  155         -
                    builder = builder.set_consumed_capacity(crate::protocol_serde::shape_consumed_capacity_multiple::de_consumed_capacity_multiple(
  156         -
                        tokens,
  157         -
                    )?);
  158         -
                }
  159         -
                "Responses" => {
  160         -
                    builder = builder.set_responses(crate::protocol_serde::shape_item_response_list::de_item_response_list(tokens)?);
         217  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
         218  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
         219  +
                /* JsonParserGenerator.kt:260 */
         220  +
                match key.to_unescaped()?.as_ref() {
         221  +
                    /* JsonParserGenerator.kt:262 */
         222  +
                    "ConsumedCapacity" => {
         223  +
                        /* JsonParserGenerator.kt:265 */
         224  +
                        builder = builder.set_consumed_capacity(
         225  +
                            /* JsonParserGenerator.kt:451 */crate::protocol_serde::shape_consumed_capacity_multiple::de_consumed_capacity_multiple(tokens)?
         226  +
                        /* JsonParserGenerator.kt:265 */);
         227  +
                        /* JsonParserGenerator.kt:262 */
         228  +
                    }
         229  +
                    /* JsonParserGenerator.kt:262 */
         230  +
                    "Responses" => {
         231  +
                        /* JsonParserGenerator.kt:265 */
         232  +
                        builder = builder.set_responses(
         233  +
                            /* JsonParserGenerator.kt:451 */
         234  +
                            crate::protocol_serde::shape_item_response_list::de_item_response_list(tokens)?, /* JsonParserGenerator.kt:265 */
         235  +
                        );
         236  +
                        /* JsonParserGenerator.kt:262 */
         237  +
                    }
         238  +
                    /* JsonParserGenerator.kt:290 */
         239  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
  161    240   
                }
  162         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
  163         -
            },
         241  +
                /* JsonParserGenerator.kt:686 */
         242  +
            }
         243  +
            /* JsonParserGenerator.kt:695 */
  164    244   
            other => {
  165    245   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
  166    246   
                    "expected object key or end object, found: {:?}",
  167    247   
                    other
  168    248   
                )))
  169         -
            }
         249  +
            } /* JsonParserGenerator.kt:685 */
  170    250   
        }
         251  +
        /* JsonParserGenerator.kt:684 */
  171    252   
    }
         253  +
    /* JsonParserGenerator.kt:250 */
  172    254   
    if tokens.next().is_some() {
         255  +
        /* JsonParserGenerator.kt:251 */
  173    256   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
  174    257   
            "found more JSON tokens after completing parsing",
  175    258   
        ));
         259  +
        /* JsonParserGenerator.kt:250 */
  176    260   
    }
         261  +
    /* JsonParserGenerator.kt:163 */
  177    262   
    Ok(builder)
         263  +
    /* JsonParserGenerator.kt:148 */
  178    264   
}

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_transact_get_items_input.rs

@@ -1,1 +22,40 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_transact_get_items_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::transact_get_items::TransactGetItemsInput,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.transact_items {
           9  +
        /* JsonSerializerGenerator.kt:484 */
    7     10   
        let mut array_2 = object.key("TransactItems").start_array();
          11  +
        /* JsonSerializerGenerator.kt:524 */
    8     12   
        for item_3 in var_1 {
          13  +
            /* SerializerUtil.kt:42 */
    9     14   
            {
          15  +
                /* JsonSerializerGenerator.kt:495 */
   10     16   
                #[allow(unused_mut)]
          17  +
                /* JsonSerializerGenerator.kt:496 */
   11     18   
                let mut object_4 = array_2.value().start_object();
          19  +
                /* JsonSerializerGenerator.kt:375 */
   12     20   
                crate::protocol_serde::shape_transact_get_item::ser_transact_get_item(&mut object_4, item_3)?;
          21  +
                /* JsonSerializerGenerator.kt:515 */
   13     22   
                object_4.finish();
          23  +
                /* SerializerUtil.kt:42 */
   14     24   
            }
          25  +
            /* JsonSerializerGenerator.kt:524 */
   15     26   
        }
          27  +
        /* JsonSerializerGenerator.kt:486 */
   16     28   
        array_2.finish();
          29  +
        /* JsonSerializerGenerator.kt:382 */
   17     30   
    }
          31  +
    /* JsonSerializerGenerator.kt:382 */
   18     32   
    if let Some(var_5) = &input.return_consumed_capacity {
          33  +
        /* JsonSerializerGenerator.kt:423 */
   19     34   
        object.key("ReturnConsumedCapacity").string(var_5.as_str());
          35  +
        /* JsonSerializerGenerator.kt:382 */
   20     36   
    }
          37  +
    /* JsonSerializerGenerator.kt:372 */
   21     38   
    Ok(())
          39  +
    /* JsonSerializerGenerator.kt:358 */
   22     40   
}

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_transact_write_item.rs

@@ -1,1 +31,58 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_transact_write_item(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::types::TransactWriteItem,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.condition_check {
           9  +
        /* JsonSerializerGenerator.kt:495 */
    7     10   
        #[allow(unused_mut)]
          11  +
        /* JsonSerializerGenerator.kt:496 */
    8     12   
        let mut object_2 = object.key("ConditionCheck").start_object();
          13  +
        /* JsonSerializerGenerator.kt:375 */
    9     14   
        crate::protocol_serde::shape_condition_check::ser_condition_check(&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.put {
          21  +
        /* JsonSerializerGenerator.kt:495 */
   13     22   
        #[allow(unused_mut)]
          23  +
        /* JsonSerializerGenerator.kt:496 */
   14     24   
        let mut object_4 = object.key("Put").start_object();
          25  +
        /* JsonSerializerGenerator.kt:375 */
   15     26   
        crate::protocol_serde::shape_put::ser_put(&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.delete {
          33  +
        /* JsonSerializerGenerator.kt:495 */
   19     34   
        #[allow(unused_mut)]
          35  +
        /* JsonSerializerGenerator.kt:496 */
   20     36   
        let mut object_6 = object.key("Delete").start_object();
          37  +
        /* JsonSerializerGenerator.kt:375 */
   21     38   
        crate::protocol_serde::shape_delete::ser_delete(&mut object_6, var_5)?;
          39  +
        /* JsonSerializerGenerator.kt:515 */
   22     40   
        object_6.finish();
          41  +
        /* JsonSerializerGenerator.kt:382 */
   23     42   
    }
          43  +
    /* JsonSerializerGenerator.kt:382 */
   24     44   
    if let Some(var_7) = &input.update {
          45  +
        /* JsonSerializerGenerator.kt:495 */
   25     46   
        #[allow(unused_mut)]
          47  +
        /* JsonSerializerGenerator.kt:496 */
   26     48   
        let mut object_8 = object.key("Update").start_object();
          49  +
        /* JsonSerializerGenerator.kt:375 */
   27     50   
        crate::protocol_serde::shape_update::ser_update(&mut object_8, var_7)?;
          51  +
        /* JsonSerializerGenerator.kt:515 */
   28     52   
        object_8.finish();
          53  +
        /* JsonSerializerGenerator.kt:382 */
   29     54   
    }
          55  +
    /* JsonSerializerGenerator.kt:372 */
   30     56   
    Ok(())
          57  +
    /* JsonSerializerGenerator.kt:358 */
   31     58   
}

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_transact_write_items.rs

@@ -1,1 +225,313 @@
    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_transact_write_items_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::transact_write_items::TransactWriteItemsOutput,
    9     11   
    crate::operation::transact_write_items::TransactWriteItemsError,
   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::transact_write_items::TransactWriteItemsError::unhandled)?;
          18  +
    /* ProtocolParserGenerator.kt:120 */
   14     19   
    let generic = generic_builder.build();
          20  +
    /* ProtocolParserGenerator.kt:122 */
   15     21   
    let error_code = match generic.code() {
   16     22   
        Some(code) => code,
   17     23   
        None => return Err(crate::operation::transact_write_items::TransactWriteItemsError::unhandled(generic)),
   18     24   
    };
   19     25   
   20     26   
    let _error_message = generic.message().map(|msg| msg.to_owned());
          27  +
    /* ProtocolParserGenerator.kt:133 */
   21     28   
    Err(match error_code {
          29  +
        /* ProtocolParserGenerator.kt:139 */
   22     30   
        "IdempotentParameterMismatchException" => {
   23     31   
            crate::operation::transact_write_items::TransactWriteItemsError::IdempotentParameterMismatchError({
          32  +
                /* RustType.kt:516 */
   24     33   
                #[allow(unused_mut)]
   25         -
                let mut tmp = {
   26         -
                    #[allow(unused_mut)]
   27         -
                    let mut output = crate::types::error::builders::IdempotentParameterMismatchErrorBuilder::default();
   28         -
                    output =
   29         -
                        crate::protocol_serde::shape_idempotent_parameter_mismatch_exception::de_idempotent_parameter_mismatch_exception_json_err(
   30         -
                            _response_body,
   31         -
                            output,
   32         -
                        )
   33         -
                        .map_err(crate::operation::transact_write_items::TransactWriteItemsError::unhandled)?;
   34         -
                    let output = output.meta(generic);
   35         -
                    output.build()
   36         -
                };
          34  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          35  +
                /* ProtocolParserGenerator.kt:146 */ {
          36  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          37  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::IdempotentParameterMismatchErrorBuilder::default();
          38  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_idempotent_parameter_mismatch_exception::de_idempotent_parameter_mismatch_exception_json_err(_response_body, output).map_err(crate::operation::transact_write_items::TransactWriteItemsError::unhandled)?;
          39  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          40  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
          41  +
                /* ProtocolParserGenerator.kt:146 */}
          42  +
            /* ProtocolParserGenerator.kt:145 */;
          43  +
                /* ProtocolParserGenerator.kt:170 */
   37     44   
                if tmp.message.is_none() {
   38     45   
                    tmp.message = _error_message;
   39     46   
                }
          47  +
                /* ProtocolParserGenerator.kt:179 */
   40     48   
                tmp
          49  +
                /* ProtocolParserGenerator.kt:139 */
   41     50   
            })
   42     51   
        }
          52  +
        /* ProtocolParserGenerator.kt:139 */
   43     53   
        "InternalServerError" => crate::operation::transact_write_items::TransactWriteItemsError::InternalServerError({
          54  +
            /* RustType.kt:516 */
   44     55   
            #[allow(unused_mut)]
   45         -
            let mut tmp = {
   46         -
                #[allow(unused_mut)]
   47         -
                let mut output = crate::types::error::builders::InternalServerErrorBuilder::default();
   48         -
                output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output)
   49         -
                    .map_err(crate::operation::transact_write_items::TransactWriteItemsError::unhandled)?;
   50         -
                let output = output.meta(generic);
   51         -
                output.build()
   52         -
            };
          56  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          57  +
                /* ProtocolParserGenerator.kt:146 */ {
          58  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          59  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::InternalServerErrorBuilder::default();
          60  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output).map_err(crate::operation::transact_write_items::TransactWriteItemsError::unhandled)?;
          61  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          62  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
          63  +
                /* ProtocolParserGenerator.kt:146 */}
          64  +
            /* ProtocolParserGenerator.kt:145 */;
          65  +
            /* ProtocolParserGenerator.kt:170 */
   53     66   
            if tmp.message.is_none() {
   54     67   
                tmp.message = _error_message;
   55     68   
            }
          69  +
            /* ProtocolParserGenerator.kt:179 */
   56     70   
            tmp
          71  +
            /* ProtocolParserGenerator.kt:139 */
   57     72   
        }),
          73  +
        /* ProtocolParserGenerator.kt:139 */
   58     74   
        "InvalidEndpointException" => crate::operation::transact_write_items::TransactWriteItemsError::InvalidEndpointError({
          75  +
            /* RustType.kt:516 */
   59     76   
            #[allow(unused_mut)]
   60         -
            let mut tmp = {
   61         -
                #[allow(unused_mut)]
   62         -
                let mut output = crate::types::error::builders::InvalidEndpointErrorBuilder::default();
   63         -
                output = crate::protocol_serde::shape_invalid_endpoint_exception::de_invalid_endpoint_exception_json_err(_response_body, output)
   64         -
                    .map_err(crate::operation::transact_write_items::TransactWriteItemsError::unhandled)?;
   65         -
                let output = output.meta(generic);
   66         -
                output.build()
   67         -
            };
          77  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          78  +
                /* ProtocolParserGenerator.kt:146 */ {
          79  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          80  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::InvalidEndpointErrorBuilder::default();
          81  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_invalid_endpoint_exception::de_invalid_endpoint_exception_json_err(_response_body, output).map_err(crate::operation::transact_write_items::TransactWriteItemsError::unhandled)?;
          82  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          83  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
          84  +
                /* ProtocolParserGenerator.kt:146 */}
          85  +
            /* ProtocolParserGenerator.kt:145 */;
          86  +
            /* ProtocolParserGenerator.kt:170 */
   68     87   
            if tmp.message.is_none() {
   69     88   
                tmp.message = _error_message;
   70     89   
            }
          90  +
            /* ProtocolParserGenerator.kt:179 */
   71     91   
            tmp
          92  +
            /* ProtocolParserGenerator.kt:139 */
   72     93   
        }),
          94  +
        /* ProtocolParserGenerator.kt:139 */
   73     95   
        "ProvisionedThroughputExceededException" => {
   74     96   
            crate::operation::transact_write_items::TransactWriteItemsError::ProvisionedThroughputExceededError({
          97  +
                /* RustType.kt:516 */
   75     98   
                #[allow(unused_mut)]
   76         -
                let mut tmp = {
   77         -
                    #[allow(unused_mut)]
   78         -
                    let mut output = crate::types::error::builders::ProvisionedThroughputExceededErrorBuilder::default();
   79         -
                    output = crate::protocol_serde::shape_provisioned_throughput_exceeded_exception::de_provisioned_throughput_exceeded_exception_json_err(_response_body, output).map_err(crate::operation::transact_write_items::TransactWriteItemsError::unhandled)?;
   80         -
                    let output = output.meta(generic);
   81         -
                    output.build()
   82         -
                };
          99  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
         100  +
                /* ProtocolParserGenerator.kt:146 */ {
         101  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
         102  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::ProvisionedThroughputExceededErrorBuilder::default();
         103  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_provisioned_throughput_exceeded_exception::de_provisioned_throughput_exceeded_exception_json_err(_response_body, output).map_err(crate::operation::transact_write_items::TransactWriteItemsError::unhandled)?;
         104  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
         105  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
         106  +
                /* ProtocolParserGenerator.kt:146 */}
         107  +
            /* ProtocolParserGenerator.kt:145 */;
         108  +
                /* ProtocolParserGenerator.kt:170 */
   83    109   
                if tmp.message.is_none() {
   84    110   
                    tmp.message = _error_message;
   85    111   
                }
         112  +
                /* ProtocolParserGenerator.kt:179 */
   86    113   
                tmp
         114  +
                /* ProtocolParserGenerator.kt:139 */
   87    115   
            })
   88    116   
        }
         117  +
        /* ProtocolParserGenerator.kt:139 */
   89    118   
        "RequestLimitExceeded" => crate::operation::transact_write_items::TransactWriteItemsError::RequestLimitExceeded({
         119  +
            /* RustType.kt:516 */
   90    120   
            #[allow(unused_mut)]
   91         -
            let mut tmp = {
   92         -
                #[allow(unused_mut)]
   93         -
                let mut output = crate::types::error::builders::RequestLimitExceededBuilder::default();
   94         -
                output = crate::protocol_serde::shape_request_limit_exceeded::de_request_limit_exceeded_json_err(_response_body, output)
   95         -
                    .map_err(crate::operation::transact_write_items::TransactWriteItemsError::unhandled)?;
   96         -
                let output = output.meta(generic);
   97         -
                output.build()
   98         -
            };
         121  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
         122  +
                /* ProtocolParserGenerator.kt:146 */ {
         123  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
         124  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::RequestLimitExceededBuilder::default();
         125  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_request_limit_exceeded::de_request_limit_exceeded_json_err(_response_body, output).map_err(crate::operation::transact_write_items::TransactWriteItemsError::unhandled)?;
         126  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
         127  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
         128  +
                /* ProtocolParserGenerator.kt:146 */}
         129  +
            /* ProtocolParserGenerator.kt:145 */;
         130  +
            /* ProtocolParserGenerator.kt:170 */
   99    131   
            if tmp.message.is_none() {
  100    132   
                tmp.message = _error_message;
  101    133   
            }
         134  +
            /* ProtocolParserGenerator.kt:179 */
  102    135   
            tmp
         136  +
            /* ProtocolParserGenerator.kt:139 */
  103    137   
        }),
         138  +
        /* ProtocolParserGenerator.kt:139 */
  104    139   
        "ResourceNotFoundException" => crate::operation::transact_write_items::TransactWriteItemsError::ResourceNotFoundError({
         140  +
            /* RustType.kt:516 */
  105    141   
            #[allow(unused_mut)]
  106         -
            let mut tmp = {
  107         -
                #[allow(unused_mut)]
  108         -
                let mut output = crate::types::error::builders::ResourceNotFoundErrorBuilder::default();
  109         -
                output = crate::protocol_serde::shape_resource_not_found_exception::de_resource_not_found_exception_json_err(_response_body, output)
  110         -
                    .map_err(crate::operation::transact_write_items::TransactWriteItemsError::unhandled)?;
  111         -
                let output = output.meta(generic);
  112         -
                output.build()
  113         -
            };
         142  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
         143  +
                /* ProtocolParserGenerator.kt:146 */ {
         144  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
         145  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::ResourceNotFoundErrorBuilder::default();
         146  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_resource_not_found_exception::de_resource_not_found_exception_json_err(_response_body, output).map_err(crate::operation::transact_write_items::TransactWriteItemsError::unhandled)?;
         147  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
         148  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
         149  +
                /* ProtocolParserGenerator.kt:146 */}
         150  +
            /* ProtocolParserGenerator.kt:145 */;
         151  +
            /* ProtocolParserGenerator.kt:170 */
  114    152   
            if tmp.message.is_none() {
  115    153   
                tmp.message = _error_message;
  116    154   
            }
         155  +
            /* ProtocolParserGenerator.kt:179 */
  117    156   
            tmp
         157  +
            /* ProtocolParserGenerator.kt:139 */
  118    158   
        }),
         159  +
        /* ProtocolParserGenerator.kt:139 */
  119    160   
        "TransactionCanceledException" => crate::operation::transact_write_items::TransactWriteItemsError::TransactionCanceledError({
         161  +
            /* RustType.kt:516 */
  120    162   
            #[allow(unused_mut)]
  121         -
            let mut tmp = {
  122         -
                #[allow(unused_mut)]
  123         -
                let mut output = crate::types::error::builders::TransactionCanceledErrorBuilder::default();
  124         -
                output =
  125         -
                    crate::protocol_serde::shape_transaction_canceled_exception::de_transaction_canceled_exception_json_err(_response_body, output)
  126         -
                        .map_err(crate::operation::transact_write_items::TransactWriteItemsError::unhandled)?;
  127         -
                let output = output.meta(generic);
  128         -
                output.build()
  129         -
            };
         163  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
         164  +
                /* ProtocolParserGenerator.kt:146 */ {
         165  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
         166  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::TransactionCanceledErrorBuilder::default();
         167  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_transaction_canceled_exception::de_transaction_canceled_exception_json_err(_response_body, output).map_err(crate::operation::transact_write_items::TransactWriteItemsError::unhandled)?;
         168  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
         169  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
         170  +
                /* ProtocolParserGenerator.kt:146 */}
         171  +
            /* ProtocolParserGenerator.kt:145 */;
         172  +
            /* ProtocolParserGenerator.kt:170 */
  130    173   
            if tmp.message.is_none() {
  131    174   
                tmp.message = _error_message;
  132    175   
            }
         176  +
            /* ProtocolParserGenerator.kt:179 */
  133    177   
            tmp
         178  +
            /* ProtocolParserGenerator.kt:139 */
  134    179   
        }),
         180  +
        /* ProtocolParserGenerator.kt:139 */
  135    181   
        "TransactionInProgressException" => crate::operation::transact_write_items::TransactWriteItemsError::TransactionInProgressError({
         182  +
            /* RustType.kt:516 */
  136    183   
            #[allow(unused_mut)]
  137         -
            let mut tmp = {
  138         -
                #[allow(unused_mut)]
  139         -
                let mut output = crate::types::error::builders::TransactionInProgressErrorBuilder::default();
  140         -
                output = crate::protocol_serde::shape_transaction_in_progress_exception::de_transaction_in_progress_exception_json_err(
  141         -
                    _response_body,
  142         -
                    output,
  143         -
                )
  144         -
                .map_err(crate::operation::transact_write_items::TransactWriteItemsError::unhandled)?;
  145         -
                let output = output.meta(generic);
  146         -
                output.build()
  147         -
            };
         184  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
         185  +
                /* ProtocolParserGenerator.kt:146 */ {
         186  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
         187  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::TransactionInProgressErrorBuilder::default();
         188  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_transaction_in_progress_exception::de_transaction_in_progress_exception_json_err(_response_body, output).map_err(crate::operation::transact_write_items::TransactWriteItemsError::unhandled)?;
         189  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
         190  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
         191  +
                /* ProtocolParserGenerator.kt:146 */}
         192  +
            /* ProtocolParserGenerator.kt:145 */;
         193  +
            /* ProtocolParserGenerator.kt:170 */
  148    194   
            if tmp.message.is_none() {
  149    195   
                tmp.message = _error_message;
  150    196   
            }
         197  +
            /* ProtocolParserGenerator.kt:179 */
  151    198   
            tmp
         199  +
            /* ProtocolParserGenerator.kt:139 */
  152    200   
        }),
  153         -
        _ => crate::operation::transact_write_items::TransactWriteItemsError::generic(generic),
         201  +
        /* ProtocolParserGenerator.kt:182 */
         202  +
        _ => crate::operation::transact_write_items::TransactWriteItemsError::generic(generic), /* ProtocolParserGenerator.kt:133 */
  154    203   
    })
         204  +
    /* ProtocolParserGenerator.kt:99 */
  155    205   
}
  156    206   
         207  +
/* RustType.kt:516 */
  157    208   
#[allow(clippy::unnecessary_wraps)]
         209  +
/* ProtocolParserGenerator.kt:71 */
  158    210   
pub fn de_transact_write_items_http_response(
  159    211   
    _response_status: u16,
  160    212   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
  161    213   
    _response_body: &[u8],
  162    214   
) -> std::result::Result<
  163    215   
    crate::operation::transact_write_items::TransactWriteItemsOutput,
  164    216   
    crate::operation::transact_write_items::TransactWriteItemsError,
  165    217   
> {
         218  +
    /* ProtocolParserGenerator.kt:77 */
  166    219   
    Ok({
         220  +
        /* RustType.kt:516 */
  167    221   
        #[allow(unused_mut)]
         222  +
        /* ProtocolParserGenerator.kt:240 */
  168    223   
        let mut output = crate::operation::transact_write_items::builders::TransactWriteItemsOutputBuilder::default();
         224  +
        /* ProtocolParserGenerator.kt:247 */
  169    225   
        output = crate::protocol_serde::shape_transact_write_items::de_transact_write_items(_response_body, output)
  170    226   
            .map_err(crate::operation::transact_write_items::TransactWriteItemsError::unhandled)?;
         227  +
        /* ClientBuilderInstantiator.kt:56 */
  171    228   
        output.build()
         229  +
        /* ProtocolParserGenerator.kt:77 */
  172    230   
    })
         231  +
    /* ProtocolParserGenerator.kt:71 */
  173    232   
}
  174    233   
         234  +
/* JsonSerializerGenerator.kt:287 */
  175    235   
pub fn ser_transact_write_items_input(
  176    236   
    input: &crate::operation::transact_write_items::TransactWriteItemsInput,
  177    237   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
         238  +
    /* JsonSerializerGenerator.kt:291 */
  178    239   
    let mut out = String::new();
         240  +
    /* JsonSerializerGenerator.kt:292 */
  179    241   
    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
         242  +
    /* JsonSerializerGenerator.kt:375 */
  180    243   
    crate::protocol_serde::shape_transact_write_items_input::ser_transact_write_items_input_input(&mut object, input)?;
         244  +
    /* JsonSerializerGenerator.kt:295 */
  181    245   
    object.finish();
         246  +
    /* JsonSerializerGenerator.kt:296 */
  182    247   
    Ok(::aws_smithy_types::body::SdkBody::from(out))
         248  +
    /* JsonSerializerGenerator.kt:287 */
  183    249   
}
  184    250   
         251  +
/* JsonParserGenerator.kt:148 */
  185    252   
pub(crate) fn de_transact_write_items(
  186    253   
    value: &[u8],
  187    254   
    mut builder: crate::operation::transact_write_items::builders::TransactWriteItemsOutputBuilder,
  188    255   
) -> ::std::result::Result<
  189    256   
    crate::operation::transact_write_items::builders::TransactWriteItemsOutputBuilder,
  190    257   
    ::aws_smithy_json::deserialize::error::DeserializeError,
  191    258   
> {
         259  +
    /* JsonParserGenerator.kt:153 */
  192    260   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
  193    261   
    let tokens = &mut tokens_owned;
  194    262   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
         263  +
    /* JsonParserGenerator.kt:684 */
  195    264   
    loop {
         265  +
        /* JsonParserGenerator.kt:685 */
  196    266   
        match tokens.next().transpose()? {
  197         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
  198         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
  199         -
                "ConsumedCapacity" => {
  200         -
                    builder = builder.set_consumed_capacity(crate::protocol_serde::shape_consumed_capacity_multiple::de_consumed_capacity_multiple(
  201         -
                        tokens,
  202         -
                    )?);
  203         -
                }
  204         -
                "ItemCollectionMetrics" => {
  205         -
                    builder = builder.set_item_collection_metrics(
  206         -
                        crate::protocol_serde::shape_item_collection_metrics_per_table::de_item_collection_metrics_per_table(tokens)?,
  207         -
                    );
         267  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
         268  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
         269  +
                /* JsonParserGenerator.kt:260 */
         270  +
                match key.to_unescaped()?.as_ref() {
         271  +
                    /* JsonParserGenerator.kt:262 */
         272  +
                    "ConsumedCapacity" => {
         273  +
                        /* JsonParserGenerator.kt:265 */
         274  +
                        builder = builder.set_consumed_capacity(
         275  +
                            /* JsonParserGenerator.kt:451 */crate::protocol_serde::shape_consumed_capacity_multiple::de_consumed_capacity_multiple(tokens)?
         276  +
                        /* JsonParserGenerator.kt:265 */);
         277  +
                        /* JsonParserGenerator.kt:262 */
         278  +
                    }
         279  +
                    /* JsonParserGenerator.kt:262 */
         280  +
                    "ItemCollectionMetrics" => {
         281  +
                        /* JsonParserGenerator.kt:265 */
         282  +
                        builder = builder.set_item_collection_metrics(
         283  +
                            /* JsonParserGenerator.kt:509 */crate::protocol_serde::shape_item_collection_metrics_per_table::de_item_collection_metrics_per_table(tokens)?
         284  +
                        /* JsonParserGenerator.kt:265 */);
         285  +
                        /* JsonParserGenerator.kt:262 */
         286  +
                    }
         287  +
                    /* JsonParserGenerator.kt:290 */
         288  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
  208    289   
                }
  209         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
  210         -
            },
         290  +
                /* JsonParserGenerator.kt:686 */
         291  +
            }
         292  +
            /* JsonParserGenerator.kt:695 */
  211    293   
            other => {
  212    294   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
  213    295   
                    "expected object key or end object, found: {:?}",
  214    296   
                    other
  215    297   
                )))
  216         -
            }
         298  +
            } /* JsonParserGenerator.kt:685 */
  217    299   
        }
         300  +
        /* JsonParserGenerator.kt:684 */
  218    301   
    }
         302  +
    /* JsonParserGenerator.kt:250 */
  219    303   
    if tokens.next().is_some() {
         304  +
        /* JsonParserGenerator.kt:251 */
  220    305   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
  221    306   
            "found more JSON tokens after completing parsing",
  222    307   
        ));
         308  +
        /* JsonParserGenerator.kt:250 */
  223    309   
    }
         310  +
    /* JsonParserGenerator.kt:163 */
  224    311   
    Ok(builder)
         312  +
    /* JsonParserGenerator.kt:148 */
  225    313   
}