Client Test

Client Test

rev. dfb5149b65b7bcc09edd15b8e071ad43b5ac5943

Files changed:

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_describe_contributor_insights_input.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_describe_contributor_insights_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::describe_contributor_insights::DescribeContributorInsightsInput,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.table_name {
           9  +
        /* JsonSerializerGenerator.kt:423 */
    7     10   
        object.key("TableName").string(var_1.as_str());
          11  +
        /* JsonSerializerGenerator.kt:382 */
    8     12   
    }
          13  +
    /* JsonSerializerGenerator.kt:382 */
    9     14   
    if let Some(var_2) = &input.index_name {
          15  +
        /* JsonSerializerGenerator.kt:423 */
   10     16   
        object.key("IndexName").string(var_2.as_str());
          17  +
        /* JsonSerializerGenerator.kt:382 */
   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_describe_endpoints.rs

@@ -1,1 +73,114 @@
    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_describe_endpoints_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::describe_endpoints::DescribeEndpointsOutput, crate::operation::describe_endpoints::DescribeEndpointsError>
    8     10   
{
          11  +
    /* RustType.kt:516 */
    9     12   
    #[allow(unused_mut)]
          13  +
    /* ProtocolParserGenerator.kt:106 */
   10     14   
    let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(_response_status, _response_headers, _response_body)
   11     15   
        .map_err(crate::operation::describe_endpoints::DescribeEndpointsError::unhandled)?;
          16  +
    /* ProtocolParserGenerator.kt:120 */
   12     17   
    let generic = generic_builder.build();
          18  +
    /* ProtocolParserGenerator.kt:185 */
   13     19   
    Err(crate::operation::describe_endpoints::DescribeEndpointsError::generic(generic))
          20  +
    /* ProtocolParserGenerator.kt:99 */
   14     21   
}
   15     22   
          23  +
/* RustType.kt:516 */
   16     24   
#[allow(clippy::unnecessary_wraps)]
          25  +
/* ProtocolParserGenerator.kt:71 */
   17     26   
pub fn de_describe_endpoints_http_response(
   18     27   
    _response_status: u16,
   19     28   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
   20     29   
    _response_body: &[u8],
   21     30   
) -> std::result::Result<crate::operation::describe_endpoints::DescribeEndpointsOutput, crate::operation::describe_endpoints::DescribeEndpointsError>
   22     31   
{
          32  +
    /* ProtocolParserGenerator.kt:77 */
   23     33   
    Ok({
          34  +
        /* RustType.kt:516 */
   24     35   
        #[allow(unused_mut)]
          36  +
        /* ProtocolParserGenerator.kt:240 */
   25     37   
        let mut output = crate::operation::describe_endpoints::builders::DescribeEndpointsOutputBuilder::default();
          38  +
        /* ProtocolParserGenerator.kt:247 */
   26     39   
        output = crate::protocol_serde::shape_describe_endpoints::de_describe_endpoints(_response_body, output)
   27     40   
            .map_err(crate::operation::describe_endpoints::DescribeEndpointsError::unhandled)?;
          41  +
        /* ClientBuilderInstantiator.kt:46 */
   28     42   
        crate::serde_util::describe_endpoints_output_output_correct_errors(output)
   29     43   
            .build()
   30     44   
            .map_err(crate::operation::describe_endpoints::DescribeEndpointsError::unhandled)?
          45  +
        /* ProtocolParserGenerator.kt:77 */
   31     46   
    })
          47  +
    /* ProtocolParserGenerator.kt:71 */
   32     48   
}
   33     49   
          50  +
/* AwsJson.kt:152 */
   34     51   
pub fn ser_describe_endpoints_input(
   35     52   
    _input: &crate::operation::describe_endpoints::DescribeEndpointsInput,
   36     53   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
          54  +
    /* AwsJson.kt:156 */
   37     55   
    Ok(::aws_smithy_types::body::SdkBody::from("{}"))
          56  +
    /* AwsJson.kt:152 */
   38     57   
}
   39     58   
          59  +
/* JsonParserGenerator.kt:148 */
   40     60   
pub(crate) fn de_describe_endpoints(
   41     61   
    value: &[u8],
   42     62   
    mut builder: crate::operation::describe_endpoints::builders::DescribeEndpointsOutputBuilder,
   43     63   
) -> ::std::result::Result<
   44     64   
    crate::operation::describe_endpoints::builders::DescribeEndpointsOutputBuilder,
   45     65   
    ::aws_smithy_json::deserialize::error::DeserializeError,
   46     66   
> {
          67  +
    /* JsonParserGenerator.kt:153 */
   47     68   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
   48     69   
    let tokens = &mut tokens_owned;
   49     70   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
          71  +
    /* JsonParserGenerator.kt:684 */
   50     72   
    loop {
          73  +
        /* JsonParserGenerator.kt:685 */
   51     74   
        match tokens.next().transpose()? {
   52         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   53         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
   54         -
                "Endpoints" => {
   55         -
                    builder = builder.set_endpoints(crate::protocol_serde::shape_endpoints::de_endpoints(tokens)?);
          75  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
          76  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
          77  +
                /* JsonParserGenerator.kt:260 */
          78  +
                match key.to_unescaped()?.as_ref() {
          79  +
                    /* JsonParserGenerator.kt:262 */
          80  +
                    "Endpoints" => {
          81  +
                        /* JsonParserGenerator.kt:265 */
          82  +
                        builder = builder.set_endpoints(
          83  +
                            /* JsonParserGenerator.kt:451 */
          84  +
                            crate::protocol_serde::shape_endpoints::de_endpoints(tokens)?, /* JsonParserGenerator.kt:265 */
          85  +
                        );
          86  +
                        /* JsonParserGenerator.kt:262 */
          87  +
                    }
          88  +
                    /* JsonParserGenerator.kt:290 */
          89  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
   56     90   
                }
   57         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   58         -
            },
          91  +
                /* JsonParserGenerator.kt:686 */
          92  +
            }
          93  +
            /* JsonParserGenerator.kt:695 */
   59     94   
            other => {
   60     95   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   61     96   
                    "expected object key or end object, found: {:?}",
   62     97   
                    other
   63     98   
                )))
   64         -
            }
          99  +
            } /* JsonParserGenerator.kt:685 */
   65    100   
        }
         101  +
        /* JsonParserGenerator.kt:684 */
   66    102   
    }
         103  +
    /* JsonParserGenerator.kt:250 */
   67    104   
    if tokens.next().is_some() {
         105  +
        /* JsonParserGenerator.kt:251 */
   68    106   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   69    107   
            "found more JSON tokens after completing parsing",
   70    108   
        ));
         109  +
        /* JsonParserGenerator.kt:250 */
   71    110   
    }
         111  +
    /* JsonParserGenerator.kt:163 */
   72    112   
    Ok(builder)
         113  +
    /* JsonParserGenerator.kt:148 */
   73    114   
}

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

@@ -1,1 +126,191 @@
    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_describe_export_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::describe_export::DescribeExportOutput, crate::operation::describe_export::DescribeExportError> {
          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::describe_export::DescribeExportError::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::describe_export::DescribeExportError::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   
        "ExportNotFoundException" => crate::operation::describe_export::DescribeExportError::ExportNotFoundError({
          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::ExportNotFoundErrorBuilder::default();
   24         -
                output = crate::protocol_serde::shape_export_not_found_exception::de_export_not_found_exception_json_err(_response_body, output)
   25         -
                    .map_err(crate::operation::describe_export::DescribeExportError::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::ExportNotFoundErrorBuilder::default();
          34  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_export_not_found_exception::de_export_not_found_exception_json_err(_response_body, output).map_err(crate::operation::describe_export::DescribeExportError::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   
        "InternalServerError" => crate::operation::describe_export::DescribeExportError::InternalServerError({
          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::InternalServerErrorBuilder::default();
   39         -
                output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output)
   40         -
                    .map_err(crate::operation::describe_export::DescribeExportError::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::InternalServerErrorBuilder::default();
          55  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output).map_err(crate::operation::describe_export::DescribeExportError::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::describe_export::DescribeExportError::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::describe_export::DescribeExportError::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::describe_export::DescribeExportError::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   
        }),
   64         -
        _ => crate::operation::describe_export::DescribeExportError::generic(generic),
          89  +
        /* ProtocolParserGenerator.kt:182 */
          90  +
        _ => crate::operation::describe_export::DescribeExportError::generic(generic), /* ProtocolParserGenerator.kt:133 */
   65     91   
    })
          92  +
    /* ProtocolParserGenerator.kt:99 */
   66     93   
}
   67     94   
          95  +
/* RustType.kt:516 */
   68     96   
#[allow(clippy::unnecessary_wraps)]
          97  +
/* ProtocolParserGenerator.kt:71 */
   69     98   
pub fn de_describe_export_http_response(
   70     99   
    _response_status: u16,
   71    100   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
   72    101   
    _response_body: &[u8],
   73    102   
) -> std::result::Result<crate::operation::describe_export::DescribeExportOutput, crate::operation::describe_export::DescribeExportError> {
         103  +
    /* ProtocolParserGenerator.kt:77 */
   74    104   
    Ok({
         105  +
        /* RustType.kt:516 */
   75    106   
        #[allow(unused_mut)]
         107  +
        /* ProtocolParserGenerator.kt:240 */
   76    108   
        let mut output = crate::operation::describe_export::builders::DescribeExportOutputBuilder::default();
         109  +
        /* ProtocolParserGenerator.kt:247 */
   77    110   
        output = crate::protocol_serde::shape_describe_export::de_describe_export(_response_body, output)
   78    111   
            .map_err(crate::operation::describe_export::DescribeExportError::unhandled)?;
         112  +
        /* ClientBuilderInstantiator.kt:56 */
   79    113   
        output.build()
         114  +
        /* ProtocolParserGenerator.kt:77 */
   80    115   
    })
         116  +
    /* ProtocolParserGenerator.kt:71 */
   81    117   
}
   82    118   
         119  +
/* JsonSerializerGenerator.kt:287 */
   83    120   
pub fn ser_describe_export_input(
   84    121   
    input: &crate::operation::describe_export::DescribeExportInput,
   85    122   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
         123  +
    /* JsonSerializerGenerator.kt:291 */
   86    124   
    let mut out = String::new();
         125  +
    /* JsonSerializerGenerator.kt:292 */
   87    126   
    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
         127  +
    /* JsonSerializerGenerator.kt:375 */
   88    128   
    crate::protocol_serde::shape_describe_export_input::ser_describe_export_input_input(&mut object, input)?;
         129  +
    /* JsonSerializerGenerator.kt:295 */
   89    130   
    object.finish();
         131  +
    /* JsonSerializerGenerator.kt:296 */
   90    132   
    Ok(::aws_smithy_types::body::SdkBody::from(out))
         133  +
    /* JsonSerializerGenerator.kt:287 */
   91    134   
}
   92    135   
         136  +
/* JsonParserGenerator.kt:148 */
   93    137   
pub(crate) fn de_describe_export(
   94    138   
    value: &[u8],
   95    139   
    mut builder: crate::operation::describe_export::builders::DescribeExportOutputBuilder,
   96    140   
) -> ::std::result::Result<
   97    141   
    crate::operation::describe_export::builders::DescribeExportOutputBuilder,
   98    142   
    ::aws_smithy_json::deserialize::error::DeserializeError,
   99    143   
> {
         144  +
    /* JsonParserGenerator.kt:153 */
  100    145   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
  101    146   
    let tokens = &mut tokens_owned;
  102    147   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
         148  +
    /* JsonParserGenerator.kt:684 */
  103    149   
    loop {
         150  +
        /* JsonParserGenerator.kt:685 */
  104    151   
        match tokens.next().transpose()? {
  105         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
  106         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
  107         -
                "ExportDescription" => {
  108         -
                    builder = builder.set_export_description(crate::protocol_serde::shape_export_description::de_export_description(tokens)?);
         152  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
         153  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
         154  +
                /* JsonParserGenerator.kt:260 */
         155  +
                match key.to_unescaped()?.as_ref() {
         156  +
                    /* JsonParserGenerator.kt:262 */
         157  +
                    "ExportDescription" => {
         158  +
                        /* JsonParserGenerator.kt:265 */
         159  +
                        builder = builder.set_export_description(
         160  +
                            /* JsonParserGenerator.kt:544 */
         161  +
                            crate::protocol_serde::shape_export_description::de_export_description(tokens)?, /* JsonParserGenerator.kt:265 */
         162  +
                        );
         163  +
                        /* JsonParserGenerator.kt:262 */
         164  +
                    }
         165  +
                    /* JsonParserGenerator.kt:290 */
         166  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
  109    167   
                }
  110         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
  111         -
            },
         168  +
                /* JsonParserGenerator.kt:686 */
         169  +
            }
         170  +
            /* JsonParserGenerator.kt:695 */
  112    171   
            other => {
  113    172   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
  114    173   
                    "expected object key or end object, found: {:?}",
  115    174   
                    other
  116    175   
                )))
  117         -
            }
         176  +
            } /* JsonParserGenerator.kt:685 */
  118    177   
        }
         178  +
        /* JsonParserGenerator.kt:684 */
  119    179   
    }
         180  +
    /* JsonParserGenerator.kt:250 */
  120    181   
    if tokens.next().is_some() {
         182  +
        /* JsonParserGenerator.kt:251 */
  121    183   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
  122    184   
            "found more JSON tokens after completing parsing",
  123    185   
        ));
         186  +
        /* JsonParserGenerator.kt:250 */
  124    187   
    }
         188  +
    /* JsonParserGenerator.kt:163 */
  125    189   
    Ok(builder)
         190  +
    /* JsonParserGenerator.kt:148 */
  126    191   
}

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

@@ -1,1 +10,16 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_describe_export_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::describe_export::DescribeExportInput,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.export_arn {
           9  +
        /* JsonSerializerGenerator.kt:423 */
    7     10   
        object.key("ExportArn").string(var_1.as_str());
          11  +
        /* JsonSerializerGenerator.kt:382 */
    8     12   
    }
          13  +
    /* JsonSerializerGenerator.kt:372 */
    9     14   
    Ok(())
          15  +
    /* JsonSerializerGenerator.kt:358 */
   10     16   
}

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

@@ -1,1 +137,196 @@
    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_describe_global_table_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::describe_global_table::DescribeGlobalTableOutput,
    9     11   
    crate::operation::describe_global_table::DescribeGlobalTableError,
   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::describe_global_table::DescribeGlobalTableError::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::describe_global_table::DescribeGlobalTableError::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   
        "GlobalTableNotFoundException" => crate::operation::describe_global_table::DescribeGlobalTableError::GlobalTableNotFoundError({
          31  +
            /* RustType.kt:516 */
   23     32   
            #[allow(unused_mut)]
   24         -
            let mut tmp = {
   25         -
                #[allow(unused_mut)]
   26         -
                let mut output = crate::types::error::builders::GlobalTableNotFoundErrorBuilder::default();
   27         -
                output = crate::protocol_serde::shape_global_table_not_found_exception::de_global_table_not_found_exception_json_err(
   28         -
                    _response_body,
   29         -
                    output,
   30         -
                )
   31         -
                .map_err(crate::operation::describe_global_table::DescribeGlobalTableError::unhandled)?;
   32         -
                let output = output.meta(generic);
   33         -
                output.build()
   34         -
            };
          33  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          34  +
                /* ProtocolParserGenerator.kt:146 */ {
          35  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          36  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::GlobalTableNotFoundErrorBuilder::default();
          37  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_global_table_not_found_exception::de_global_table_not_found_exception_json_err(_response_body, output).map_err(crate::operation::describe_global_table::DescribeGlobalTableError::unhandled)?;
          38  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          39  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
          40  +
                /* ProtocolParserGenerator.kt:146 */}
          41  +
            /* ProtocolParserGenerator.kt:145 */;
          42  +
            /* ProtocolParserGenerator.kt:170 */
   35     43   
            if tmp.message.is_none() {
   36     44   
                tmp.message = _error_message;
   37     45   
            }
          46  +
            /* ProtocolParserGenerator.kt:179 */
   38     47   
            tmp
          48  +
            /* ProtocolParserGenerator.kt:139 */
   39     49   
        }),
          50  +
        /* ProtocolParserGenerator.kt:139 */
   40     51   
        "InternalServerError" => crate::operation::describe_global_table::DescribeGlobalTableError::InternalServerError({
          52  +
            /* RustType.kt:516 */
   41     53   
            #[allow(unused_mut)]
   42         -
            let mut tmp = {
   43         -
                #[allow(unused_mut)]
   44         -
                let mut output = crate::types::error::builders::InternalServerErrorBuilder::default();
   45         -
                output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output)
   46         -
                    .map_err(crate::operation::describe_global_table::DescribeGlobalTableError::unhandled)?;
   47         -
                let output = output.meta(generic);
   48         -
                output.build()
   49         -
            };
          54  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          55  +
                /* ProtocolParserGenerator.kt:146 */ {
          56  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          57  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::InternalServerErrorBuilder::default();
          58  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output).map_err(crate::operation::describe_global_table::DescribeGlobalTableError::unhandled)?;
          59  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          60  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
          61  +
                /* ProtocolParserGenerator.kt:146 */}
          62  +
            /* ProtocolParserGenerator.kt:145 */;
          63  +
            /* ProtocolParserGenerator.kt:170 */
   50     64   
            if tmp.message.is_none() {
   51     65   
                tmp.message = _error_message;
   52     66   
            }
          67  +
            /* ProtocolParserGenerator.kt:179 */
   53     68   
            tmp
          69  +
            /* ProtocolParserGenerator.kt:139 */
   54     70   
        }),
          71  +
        /* ProtocolParserGenerator.kt:139 */
   55     72   
        "InvalidEndpointException" => crate::operation::describe_global_table::DescribeGlobalTableError::InvalidEndpointError({
          73  +
            /* RustType.kt:516 */
   56     74   
            #[allow(unused_mut)]
   57         -
            let mut tmp = {
   58         -
                #[allow(unused_mut)]
   59         -
                let mut output = crate::types::error::builders::InvalidEndpointErrorBuilder::default();
   60         -
                output = crate::protocol_serde::shape_invalid_endpoint_exception::de_invalid_endpoint_exception_json_err(_response_body, output)
   61         -
                    .map_err(crate::operation::describe_global_table::DescribeGlobalTableError::unhandled)?;
   62         -
                let output = output.meta(generic);
   63         -
                output.build()
   64         -
            };
          75  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          76  +
                /* ProtocolParserGenerator.kt:146 */ {
          77  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          78  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::InvalidEndpointErrorBuilder::default();
          79  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_invalid_endpoint_exception::de_invalid_endpoint_exception_json_err(_response_body, output).map_err(crate::operation::describe_global_table::DescribeGlobalTableError::unhandled)?;
          80  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          81  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
          82  +
                /* ProtocolParserGenerator.kt:146 */}
          83  +
            /* ProtocolParserGenerator.kt:145 */;
          84  +
            /* ProtocolParserGenerator.kt:170 */
   65     85   
            if tmp.message.is_none() {
   66     86   
                tmp.message = _error_message;
   67     87   
            }
          88  +
            /* ProtocolParserGenerator.kt:179 */
   68     89   
            tmp
          90  +
            /* ProtocolParserGenerator.kt:139 */
   69     91   
        }),
   70         -
        _ => crate::operation::describe_global_table::DescribeGlobalTableError::generic(generic),
          92  +
        /* ProtocolParserGenerator.kt:182 */
          93  +
        _ => crate::operation::describe_global_table::DescribeGlobalTableError::generic(generic), /* ProtocolParserGenerator.kt:133 */
   71     94   
    })
          95  +
    /* ProtocolParserGenerator.kt:99 */
   72     96   
}
   73     97   
          98  +
/* RustType.kt:516 */
   74     99   
#[allow(clippy::unnecessary_wraps)]
         100  +
/* ProtocolParserGenerator.kt:71 */
   75    101   
pub fn de_describe_global_table_http_response(
   76    102   
    _response_status: u16,
   77    103   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
   78    104   
    _response_body: &[u8],
   79    105   
) -> std::result::Result<
   80    106   
    crate::operation::describe_global_table::DescribeGlobalTableOutput,
   81    107   
    crate::operation::describe_global_table::DescribeGlobalTableError,
   82    108   
> {
         109  +
    /* ProtocolParserGenerator.kt:77 */
   83    110   
    Ok({
         111  +
        /* RustType.kt:516 */
   84    112   
        #[allow(unused_mut)]
         113  +
        /* ProtocolParserGenerator.kt:240 */
   85    114   
        let mut output = crate::operation::describe_global_table::builders::DescribeGlobalTableOutputBuilder::default();
         115  +
        /* ProtocolParserGenerator.kt:247 */
   86    116   
        output = crate::protocol_serde::shape_describe_global_table::de_describe_global_table(_response_body, output)
   87    117   
            .map_err(crate::operation::describe_global_table::DescribeGlobalTableError::unhandled)?;
         118  +
        /* ClientBuilderInstantiator.kt:56 */
   88    119   
        output.build()
         120  +
        /* ProtocolParserGenerator.kt:77 */
   89    121   
    })
         122  +
    /* ProtocolParserGenerator.kt:71 */
   90    123   
}
   91    124   
         125  +
/* JsonSerializerGenerator.kt:287 */
   92    126   
pub fn ser_describe_global_table_input(
   93    127   
    input: &crate::operation::describe_global_table::DescribeGlobalTableInput,
   94    128   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
         129  +
    /* JsonSerializerGenerator.kt:291 */
   95    130   
    let mut out = String::new();
         131  +
    /* JsonSerializerGenerator.kt:292 */
   96    132   
    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
         133  +
    /* JsonSerializerGenerator.kt:375 */
   97    134   
    crate::protocol_serde::shape_describe_global_table_input::ser_describe_global_table_input_input(&mut object, input)?;
         135  +
    /* JsonSerializerGenerator.kt:295 */
   98    136   
    object.finish();
         137  +
    /* JsonSerializerGenerator.kt:296 */
   99    138   
    Ok(::aws_smithy_types::body::SdkBody::from(out))
         139  +
    /* JsonSerializerGenerator.kt:287 */
  100    140   
}
  101    141   
         142  +
/* JsonParserGenerator.kt:148 */
  102    143   
pub(crate) fn de_describe_global_table(
  103    144   
    value: &[u8],
  104    145   
    mut builder: crate::operation::describe_global_table::builders::DescribeGlobalTableOutputBuilder,
  105    146   
) -> ::std::result::Result<
  106    147   
    crate::operation::describe_global_table::builders::DescribeGlobalTableOutputBuilder,
  107    148   
    ::aws_smithy_json::deserialize::error::DeserializeError,
  108    149   
> {
         150  +
    /* JsonParserGenerator.kt:153 */
  109    151   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
  110    152   
    let tokens = &mut tokens_owned;
  111    153   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
         154  +
    /* JsonParserGenerator.kt:684 */
  112    155   
    loop {
         156  +
        /* JsonParserGenerator.kt:685 */
  113    157   
        match tokens.next().transpose()? {
  114         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
  115         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
  116         -
                "GlobalTableDescription" => {
  117         -
                    builder = builder.set_global_table_description(
  118         -
                        crate::protocol_serde::shape_global_table_description::de_global_table_description(tokens)?,
  119         -
                    );
         158  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
         159  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
         160  +
                /* JsonParserGenerator.kt:260 */
         161  +
                match key.to_unescaped()?.as_ref() {
         162  +
                    /* JsonParserGenerator.kt:262 */
         163  +
                    "GlobalTableDescription" => {
         164  +
                        /* JsonParserGenerator.kt:265 */
         165  +
                        builder = builder.set_global_table_description(
         166  +
                            /* JsonParserGenerator.kt:544 */crate::protocol_serde::shape_global_table_description::de_global_table_description(tokens)?
         167  +
                        /* JsonParserGenerator.kt:265 */);
         168  +
                        /* JsonParserGenerator.kt:262 */
         169  +
                    }
         170  +
                    /* JsonParserGenerator.kt:290 */
         171  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
  120    172   
                }
  121         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
  122         -
            },
         173  +
                /* JsonParserGenerator.kt:686 */
         174  +
            }
         175  +
            /* JsonParserGenerator.kt:695 */
  123    176   
            other => {
  124    177   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
  125    178   
                    "expected object key or end object, found: {:?}",
  126    179   
                    other
  127    180   
                )))
  128         -
            }
         181  +
            } /* JsonParserGenerator.kt:685 */
  129    182   
        }
         183  +
        /* JsonParserGenerator.kt:684 */
  130    184   
    }
         185  +
    /* JsonParserGenerator.kt:250 */
  131    186   
    if tokens.next().is_some() {
         187  +
        /* JsonParserGenerator.kt:251 */
  132    188   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
  133    189   
            "found more JSON tokens after completing parsing",
  134    190   
        ));
         191  +
        /* JsonParserGenerator.kt:250 */
  135    192   
    }
         193  +
    /* JsonParserGenerator.kt:163 */
  136    194   
    Ok(builder)
         195  +
    /* JsonParserGenerator.kt:148 */
  137    196   
}

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

@@ -1,1 +10,16 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_describe_global_table_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::describe_global_table::DescribeGlobalTableInput,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.global_table_name {
           9  +
        /* JsonSerializerGenerator.kt:423 */
    7     10   
        object.key("GlobalTableName").string(var_1.as_str());
          11  +
        /* JsonSerializerGenerator.kt:382 */
    8     12   
    }
          13  +
    /* JsonSerializerGenerator.kt:372 */
    9     14   
    Ok(())
          15  +
    /* JsonSerializerGenerator.kt:358 */
   10     16   
}

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

@@ -1,1 +146,212 @@
    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_describe_global_table_settings_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::describe_global_table_settings::DescribeGlobalTableSettingsOutput,
    9     11   
    crate::operation::describe_global_table_settings::DescribeGlobalTableSettingsError,
   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::describe_global_table_settings::DescribeGlobalTableSettingsError::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::describe_global_table_settings::DescribeGlobalTableSettingsError::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   
        "GlobalTableNotFoundException" => {
   23     31   
            crate::operation::describe_global_table_settings::DescribeGlobalTableSettingsError::GlobalTableNotFoundError({
          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::GlobalTableNotFoundErrorBuilder::default();
   28         -
                    output = crate::protocol_serde::shape_global_table_not_found_exception::de_global_table_not_found_exception_json_err(
   29         -
                        _response_body,
   30         -
                        output,
   31         -
                    )
   32         -
                    .map_err(crate::operation::describe_global_table_settings::DescribeGlobalTableSettingsError::unhandled)?;
   33         -
                    let output = output.meta(generic);
   34         -
                    output.build()
   35         -
                };
          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::GlobalTableNotFoundErrorBuilder::default();
          38  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_global_table_not_found_exception::de_global_table_not_found_exception_json_err(_response_body, output).map_err(crate::operation::describe_global_table_settings::DescribeGlobalTableSettingsError::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 */
   36     44   
                if tmp.message.is_none() {
   37     45   
                    tmp.message = _error_message;
   38     46   
                }
          47  +
                /* ProtocolParserGenerator.kt:179 */
   39     48   
                tmp
          49  +
                /* ProtocolParserGenerator.kt:139 */
   40     50   
            })
   41     51   
        }
          52  +
        /* ProtocolParserGenerator.kt:139 */
   42     53   
        "InternalServerError" => crate::operation::describe_global_table_settings::DescribeGlobalTableSettingsError::InternalServerError({
          54  +
            /* RustType.kt:516 */
   43     55   
            #[allow(unused_mut)]
   44         -
            let mut tmp = {
   45         -
                #[allow(unused_mut)]
   46         -
                let mut output = crate::types::error::builders::InternalServerErrorBuilder::default();
   47         -
                output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output)
   48         -
                    .map_err(crate::operation::describe_global_table_settings::DescribeGlobalTableSettingsError::unhandled)?;
   49         -
                let output = output.meta(generic);
   50         -
                output.build()
   51         -
            };
          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::describe_global_table_settings::DescribeGlobalTableSettingsError::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 */
   52     66   
            if tmp.message.is_none() {
   53     67   
                tmp.message = _error_message;
   54     68   
            }
          69  +
            /* ProtocolParserGenerator.kt:179 */
   55     70   
            tmp
          71  +
            /* ProtocolParserGenerator.kt:139 */
   56     72   
        }),
          73  +
        /* ProtocolParserGenerator.kt:139 */
   57     74   
        "InvalidEndpointException" => crate::operation::describe_global_table_settings::DescribeGlobalTableSettingsError::InvalidEndpointError({
          75  +
            /* RustType.kt:516 */
   58     76   
            #[allow(unused_mut)]
   59         -
            let mut tmp = {
   60         -
                #[allow(unused_mut)]
   61         -
                let mut output = crate::types::error::builders::InvalidEndpointErrorBuilder::default();
   62         -
                output = crate::protocol_serde::shape_invalid_endpoint_exception::de_invalid_endpoint_exception_json_err(_response_body, output)
   63         -
                    .map_err(crate::operation::describe_global_table_settings::DescribeGlobalTableSettingsError::unhandled)?;
   64         -
                let output = output.meta(generic);
   65         -
                output.build()
   66         -
            };
          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::describe_global_table_settings::DescribeGlobalTableSettingsError::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 */
   67     87   
            if tmp.message.is_none() {
   68     88   
                tmp.message = _error_message;
   69     89   
            }
          90  +
            /* ProtocolParserGenerator.kt:179 */
   70     91   
            tmp
          92  +
            /* ProtocolParserGenerator.kt:139 */
   71     93   
        }),
   72         -
        _ => crate::operation::describe_global_table_settings::DescribeGlobalTableSettingsError::generic(generic),
          94  +
        /* ProtocolParserGenerator.kt:182 */
          95  +
        _ => crate::operation::describe_global_table_settings::DescribeGlobalTableSettingsError::generic(generic), /* ProtocolParserGenerator.kt:133 */
   73     96   
    })
          97  +
    /* ProtocolParserGenerator.kt:99 */
   74     98   
}
   75     99   
         100  +
/* RustType.kt:516 */
   76    101   
#[allow(clippy::unnecessary_wraps)]
         102  +
/* ProtocolParserGenerator.kt:71 */
   77    103   
pub fn de_describe_global_table_settings_http_response(
   78    104   
    _response_status: u16,
   79    105   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
   80    106   
    _response_body: &[u8],
   81    107   
) -> std::result::Result<
   82    108   
    crate::operation::describe_global_table_settings::DescribeGlobalTableSettingsOutput,
   83    109   
    crate::operation::describe_global_table_settings::DescribeGlobalTableSettingsError,
   84    110   
> {
         111  +
    /* ProtocolParserGenerator.kt:77 */
   85    112   
    Ok({
         113  +
        /* RustType.kt:516 */
   86    114   
        #[allow(unused_mut)]
         115  +
        /* ProtocolParserGenerator.kt:240 */
   87    116   
        let mut output = crate::operation::describe_global_table_settings::builders::DescribeGlobalTableSettingsOutputBuilder::default();
         117  +
        /* ProtocolParserGenerator.kt:247 */
   88    118   
        output = crate::protocol_serde::shape_describe_global_table_settings::de_describe_global_table_settings(_response_body, output)
   89    119   
            .map_err(crate::operation::describe_global_table_settings::DescribeGlobalTableSettingsError::unhandled)?;
         120  +
        /* ClientBuilderInstantiator.kt:56 */
   90    121   
        output.build()
         122  +
        /* ProtocolParserGenerator.kt:77 */
   91    123   
    })
         124  +
    /* ProtocolParserGenerator.kt:71 */
   92    125   
}
   93    126   
         127  +
/* JsonSerializerGenerator.kt:287 */
   94    128   
pub fn ser_describe_global_table_settings_input(
   95    129   
    input: &crate::operation::describe_global_table_settings::DescribeGlobalTableSettingsInput,
   96    130   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
         131  +
    /* JsonSerializerGenerator.kt:291 */
   97    132   
    let mut out = String::new();
         133  +
    /* JsonSerializerGenerator.kt:292 */
   98    134   
    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
         135  +
    /* JsonSerializerGenerator.kt:375 */
   99    136   
    crate::protocol_serde::shape_describe_global_table_settings_input::ser_describe_global_table_settings_input_input(&mut object, input)?;
         137  +
    /* JsonSerializerGenerator.kt:295 */
  100    138   
    object.finish();
         139  +
    /* JsonSerializerGenerator.kt:296 */
  101    140   
    Ok(::aws_smithy_types::body::SdkBody::from(out))
         141  +
    /* JsonSerializerGenerator.kt:287 */
  102    142   
}
  103    143   
         144  +
/* JsonParserGenerator.kt:148 */
  104    145   
pub(crate) fn de_describe_global_table_settings(
  105    146   
    value: &[u8],
  106    147   
    mut builder: crate::operation::describe_global_table_settings::builders::DescribeGlobalTableSettingsOutputBuilder,
  107    148   
) -> ::std::result::Result<
  108    149   
    crate::operation::describe_global_table_settings::builders::DescribeGlobalTableSettingsOutputBuilder,
  109    150   
    ::aws_smithy_json::deserialize::error::DeserializeError,
  110    151   
> {
         152  +
    /* JsonParserGenerator.kt:153 */
  111    153   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
  112    154   
    let tokens = &mut tokens_owned;
  113    155   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
         156  +
    /* JsonParserGenerator.kt:684 */
  114    157   
    loop {
         158  +
        /* JsonParserGenerator.kt:685 */
  115    159   
        match tokens.next().transpose()? {
  116         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
  117         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
  118         -
                "GlobalTableName" => {
  119         -
                    builder = builder.set_global_table_name(
  120         -
                        ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
  121         -
                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
  122         -
                            .transpose()?,
  123         -
                    );
  124         -
                }
  125         -
                "ReplicaSettings" => {
  126         -
                    builder = builder.set_replica_settings(
  127         -
                        crate::protocol_serde::shape_replica_settings_description_list::de_replica_settings_description_list(tokens)?,
  128         -
                    );
         160  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
         161  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
         162  +
                /* JsonParserGenerator.kt:260 */
         163  +
                match key.to_unescaped()?.as_ref() {
         164  +
                    /* JsonParserGenerator.kt:262 */
         165  +
                    "GlobalTableName" => {
         166  +
                        /* JsonParserGenerator.kt:265 */
         167  +
                        builder = builder.set_global_table_name(
         168  +
                            /* JsonParserGenerator.kt:354 */
         169  +
                            ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
         170  +
                                .map(|s|
         171  +
                                /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
         172  +
                                    /* JsonParserGenerator.kt:348 */u.into_owned()
         173  +
                                /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
         174  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
         175  +
                        );
         176  +
                        /* JsonParserGenerator.kt:262 */
         177  +
                    }
         178  +
                    /* JsonParserGenerator.kt:262 */
         179  +
                    "ReplicaSettings" => {
         180  +
                        /* JsonParserGenerator.kt:265 */
         181  +
                        builder = builder.set_replica_settings(
         182  +
                            /* JsonParserGenerator.kt:451 */crate::protocol_serde::shape_replica_settings_description_list::de_replica_settings_description_list(tokens)?
         183  +
                        /* JsonParserGenerator.kt:265 */);
         184  +
                        /* JsonParserGenerator.kt:262 */
         185  +
                    }
         186  +
                    /* JsonParserGenerator.kt:290 */
         187  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
  129    188   
                }
  130         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
  131         -
            },
         189  +
                /* JsonParserGenerator.kt:686 */
         190  +
            }
         191  +
            /* JsonParserGenerator.kt:695 */
  132    192   
            other => {
  133    193   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
  134    194   
                    "expected object key or end object, found: {:?}",
  135    195   
                    other
  136    196   
                )))
  137         -
            }
         197  +
            } /* JsonParserGenerator.kt:685 */
  138    198   
        }
         199  +
        /* JsonParserGenerator.kt:684 */
  139    200   
    }
         201  +
    /* JsonParserGenerator.kt:250 */
  140    202   
    if tokens.next().is_some() {
         203  +
        /* JsonParserGenerator.kt:251 */
  141    204   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
  142    205   
            "found more JSON tokens after completing parsing",
  143    206   
        ));
         207  +
        /* JsonParserGenerator.kt:250 */
  144    208   
    }
         209  +
    /* JsonParserGenerator.kt:163 */
  145    210   
    Ok(builder)
         211  +
    /* JsonParserGenerator.kt:148 */
  146    212   
}

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

@@ -1,1 +10,16 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_describe_global_table_settings_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::describe_global_table_settings::DescribeGlobalTableSettingsInput,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.global_table_name {
           9  +
        /* JsonSerializerGenerator.kt:423 */
    7     10   
        object.key("GlobalTableName").string(var_1.as_str());
          11  +
        /* JsonSerializerGenerator.kt:382 */
    8     12   
    }
          13  +
    /* JsonSerializerGenerator.kt:372 */
    9     14   
    Ok(())
          15  +
    /* JsonSerializerGenerator.kt:358 */
   10     16   
}

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

@@ -1,1 +153,221 @@
    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_describe_kinesis_streaming_destination_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::describe_kinesis_streaming_destination::DescribeKinesisStreamingDestinationOutput,
    9     11   
    crate::operation::describe_kinesis_streaming_destination::DescribeKinesisStreamingDestinationError,
   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::describe_kinesis_streaming_destination::DescribeKinesisStreamingDestinationError::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::describe_kinesis_streaming_destination::DescribeKinesisStreamingDestinationError::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   
        "InternalServerError" => {
   23     31   
            crate::operation::describe_kinesis_streaming_destination::DescribeKinesisStreamingDestinationError::InternalServerError({
          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::InternalServerErrorBuilder::default();
   28         -
                    output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output)
   29         -
                        .map_err(crate::operation::describe_kinesis_streaming_destination::DescribeKinesisStreamingDestinationError::unhandled)?;
   30         -
                    let output = output.meta(generic);
   31         -
                    output.build()
   32         -
                };
          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::InternalServerErrorBuilder::default();
          38  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output).map_err(crate::operation::describe_kinesis_streaming_destination::DescribeKinesisStreamingDestinationError::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 */
   33     44   
                if tmp.message.is_none() {
   34     45   
                    tmp.message = _error_message;
   35     46   
                }
          47  +
                /* ProtocolParserGenerator.kt:179 */
   36     48   
                tmp
          49  +
                /* ProtocolParserGenerator.kt:139 */
   37     50   
            })
   38     51   
        }
          52  +
        /* ProtocolParserGenerator.kt:139 */
   39     53   
        "InvalidEndpointException" => {
   40     54   
            crate::operation::describe_kinesis_streaming_destination::DescribeKinesisStreamingDestinationError::InvalidEndpointError({
          55  +
                /* RustType.kt:516 */
   41     56   
                #[allow(unused_mut)]
   42         -
                let mut tmp = {
   43         -
                    #[allow(unused_mut)]
   44         -
                    let mut output = crate::types::error::builders::InvalidEndpointErrorBuilder::default();
   45         -
                    output = crate::protocol_serde::shape_invalid_endpoint_exception::de_invalid_endpoint_exception_json_err(_response_body, output)
   46         -
                        .map_err(crate::operation::describe_kinesis_streaming_destination::DescribeKinesisStreamingDestinationError::unhandled)?;
   47         -
                    let output = output.meta(generic);
   48         -
                    output.build()
   49         -
                };
          57  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          58  +
                /* ProtocolParserGenerator.kt:146 */ {
          59  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          60  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::InvalidEndpointErrorBuilder::default();
          61  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_invalid_endpoint_exception::de_invalid_endpoint_exception_json_err(_response_body, output).map_err(crate::operation::describe_kinesis_streaming_destination::DescribeKinesisStreamingDestinationError::unhandled)?;
          62  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          63  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
          64  +
                /* ProtocolParserGenerator.kt:146 */}
          65  +
            /* ProtocolParserGenerator.kt:145 */;
          66  +
                /* ProtocolParserGenerator.kt:170 */
   50     67   
                if tmp.message.is_none() {
   51     68   
                    tmp.message = _error_message;
   52     69   
                }
          70  +
                /* ProtocolParserGenerator.kt:179 */
   53     71   
                tmp
          72  +
                /* ProtocolParserGenerator.kt:139 */
   54     73   
            })
   55     74   
        }
          75  +
        /* ProtocolParserGenerator.kt:139 */
   56     76   
        "ResourceNotFoundException" => {
   57     77   
            crate::operation::describe_kinesis_streaming_destination::DescribeKinesisStreamingDestinationError::ResourceNotFoundError({
          78  +
                /* RustType.kt:516 */
   58     79   
                #[allow(unused_mut)]
   59         -
                let mut tmp = {
   60         -
                    #[allow(unused_mut)]
   61         -
                    let mut output = crate::types::error::builders::ResourceNotFoundErrorBuilder::default();
   62         -
                    output =
   63         -
                        crate::protocol_serde::shape_resource_not_found_exception::de_resource_not_found_exception_json_err(_response_body, output)
   64         -
                            .map_err(crate::operation::describe_kinesis_streaming_destination::DescribeKinesisStreamingDestinationError::unhandled)?;
   65         -
                    let output = output.meta(generic);
   66         -
                    output.build()
   67         -
                };
          80  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          81  +
                /* ProtocolParserGenerator.kt:146 */ {
          82  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          83  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::ResourceNotFoundErrorBuilder::default();
          84  +
                    /* 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::describe_kinesis_streaming_destination::DescribeKinesisStreamingDestinationError::unhandled)?;
          85  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          86  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
          87  +
                /* ProtocolParserGenerator.kt:146 */}
          88  +
            /* ProtocolParserGenerator.kt:145 */;
          89  +
                /* ProtocolParserGenerator.kt:170 */
   68     90   
                if tmp.message.is_none() {
   69     91   
                    tmp.message = _error_message;
   70     92   
                }
          93  +
                /* ProtocolParserGenerator.kt:179 */
   71     94   
                tmp
          95  +
                /* ProtocolParserGenerator.kt:139 */
   72     96   
            })
   73     97   
        }
   74         -
        _ => crate::operation::describe_kinesis_streaming_destination::DescribeKinesisStreamingDestinationError::generic(generic),
          98  +
        /* ProtocolParserGenerator.kt:182 */
          99  +
        _ => crate::operation::describe_kinesis_streaming_destination::DescribeKinesisStreamingDestinationError::generic(generic), /* ProtocolParserGenerator.kt:133 */
   75    100   
    })
         101  +
    /* ProtocolParserGenerator.kt:99 */
   76    102   
}
   77    103   
         104  +
/* RustType.kt:516 */
   78    105   
#[allow(clippy::unnecessary_wraps)]
         106  +
/* ProtocolParserGenerator.kt:71 */
   79    107   
pub fn de_describe_kinesis_streaming_destination_http_response(
   80    108   
    _response_status: u16,
   81    109   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
   82    110   
    _response_body: &[u8],
   83    111   
) -> std::result::Result<
   84    112   
    crate::operation::describe_kinesis_streaming_destination::DescribeKinesisStreamingDestinationOutput,
   85    113   
    crate::operation::describe_kinesis_streaming_destination::DescribeKinesisStreamingDestinationError,
   86    114   
> {
         115  +
    /* ProtocolParserGenerator.kt:77 */
   87    116   
    Ok({
         117  +
        /* RustType.kt:516 */
   88    118   
        #[allow(unused_mut)]
         119  +
        /* ProtocolParserGenerator.kt:240 */
   89    120   
        let mut output =
   90    121   
            crate::operation::describe_kinesis_streaming_destination::builders::DescribeKinesisStreamingDestinationOutputBuilder::default();
         122  +
        /* ProtocolParserGenerator.kt:247 */
   91    123   
        output =
   92    124   
            crate::protocol_serde::shape_describe_kinesis_streaming_destination::de_describe_kinesis_streaming_destination(_response_body, output)
   93    125   
                .map_err(crate::operation::describe_kinesis_streaming_destination::DescribeKinesisStreamingDestinationError::unhandled)?;
         126  +
        /* ClientBuilderInstantiator.kt:56 */
   94    127   
        output.build()
         128  +
        /* ProtocolParserGenerator.kt:77 */
   95    129   
    })
         130  +
    /* ProtocolParserGenerator.kt:71 */
   96    131   
}
   97    132   
         133  +
/* JsonSerializerGenerator.kt:287 */
   98    134   
pub fn ser_describe_kinesis_streaming_destination_input(
   99    135   
    input: &crate::operation::describe_kinesis_streaming_destination::DescribeKinesisStreamingDestinationInput,
  100    136   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
         137  +
    /* JsonSerializerGenerator.kt:291 */
  101    138   
    let mut out = String::new();
         139  +
    /* JsonSerializerGenerator.kt:292 */
  102    140   
    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
         141  +
    /* JsonSerializerGenerator.kt:375 */
  103    142   
    crate::protocol_serde::shape_describe_kinesis_streaming_destination_input::ser_describe_kinesis_streaming_destination_input_input(
  104    143   
        &mut object,
  105    144   
        input,
  106    145   
    )?;
         146  +
    /* JsonSerializerGenerator.kt:295 */
  107    147   
    object.finish();
         148  +
    /* JsonSerializerGenerator.kt:296 */
  108    149   
    Ok(::aws_smithy_types::body::SdkBody::from(out))
         150  +
    /* JsonSerializerGenerator.kt:287 */
  109    151   
}
  110    152   
         153  +
/* JsonParserGenerator.kt:148 */
  111    154   
pub(crate) fn de_describe_kinesis_streaming_destination(
  112    155   
    value: &[u8],
  113    156   
    mut builder: crate::operation::describe_kinesis_streaming_destination::builders::DescribeKinesisStreamingDestinationOutputBuilder,
  114    157   
) -> ::std::result::Result<
  115    158   
    crate::operation::describe_kinesis_streaming_destination::builders::DescribeKinesisStreamingDestinationOutputBuilder,
  116    159   
    ::aws_smithy_json::deserialize::error::DeserializeError,
  117    160   
> {
         161  +
    /* JsonParserGenerator.kt:153 */
  118    162   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
  119    163   
    let tokens = &mut tokens_owned;
  120    164   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
         165  +
    /* JsonParserGenerator.kt:684 */
  121    166   
    loop {
         167  +
        /* JsonParserGenerator.kt:685 */
  122    168   
        match tokens.next().transpose()? {
  123         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
  124         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
  125         -
                "TableName" => {
  126         -
                    builder = builder.set_table_name(
  127         -
                        ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
  128         -
                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
  129         -
                            .transpose()?,
  130         -
                    );
         169  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
         170  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
         171  +
                /* JsonParserGenerator.kt:260 */
         172  +
                match key.to_unescaped()?.as_ref() {
         173  +
                    /* JsonParserGenerator.kt:262 */
         174  +
                    "TableName" => {
         175  +
                        /* JsonParserGenerator.kt:265 */
         176  +
                        builder = builder.set_table_name(
         177  +
                            /* JsonParserGenerator.kt:354 */
         178  +
                            ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
         179  +
                                .map(|s|
         180  +
                                /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
         181  +
                                    /* JsonParserGenerator.kt:348 */u.into_owned()
         182  +
                                /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
         183  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
         184  +
                        );
         185  +
                        /* JsonParserGenerator.kt:262 */
         186  +
                    }
         187  +
                    /* JsonParserGenerator.kt:262 */
         188  +
                    "KinesisDataStreamDestinations" => {
         189  +
                        /* JsonParserGenerator.kt:265 */
         190  +
                        builder = builder.set_kinesis_data_stream_destinations(
         191  +
                            /* JsonParserGenerator.kt:451 */crate::protocol_serde::shape_kinesis_data_stream_destinations::de_kinesis_data_stream_destinations(tokens)?
         192  +
                        /* JsonParserGenerator.kt:265 */);
         193  +
                        /* JsonParserGenerator.kt:262 */
         194  +
                    }
         195  +
                    /* JsonParserGenerator.kt:290 */
         196  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
  131    197   
                }
  132         -
                "KinesisDataStreamDestinations" => {
  133         -
                    builder = builder.set_kinesis_data_stream_destinations(
  134         -
                        crate::protocol_serde::shape_kinesis_data_stream_destinations::de_kinesis_data_stream_destinations(tokens)?,
  135         -
                    );
  136         -
                }
  137         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
  138         -
            },
         198  +
                /* JsonParserGenerator.kt:686 */
         199  +
            }
         200  +
            /* JsonParserGenerator.kt:695 */
  139    201   
            other => {
  140    202   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
  141    203   
                    "expected object key or end object, found: {:?}",
  142    204   
                    other
  143    205   
                )))
  144         -
            }
         206  +
            } /* JsonParserGenerator.kt:685 */
  145    207   
        }
         208  +
        /* JsonParserGenerator.kt:684 */
  146    209   
    }
         210  +
    /* JsonParserGenerator.kt:250 */
  147    211   
    if tokens.next().is_some() {
         212  +
        /* JsonParserGenerator.kt:251 */
  148    213   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
  149    214   
            "found more JSON tokens after completing parsing",
  150    215   
        ));
         216  +
        /* JsonParserGenerator.kt:250 */
  151    217   
    }
         218  +
    /* JsonParserGenerator.kt:163 */
  152    219   
    Ok(builder)
         220  +
    /* JsonParserGenerator.kt:148 */
  153    221   
}

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

@@ -1,1 +10,16 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_describe_kinesis_streaming_destination_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::describe_kinesis_streaming_destination::DescribeKinesisStreamingDestinationInput,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.table_name {
           9  +
        /* JsonSerializerGenerator.kt:423 */
    7     10   
        object.key("TableName").string(var_1.as_str());
          11  +
        /* JsonSerializerGenerator.kt:382 */
    8     12   
    }
          13  +
    /* JsonSerializerGenerator.kt:372 */
    9     14   
    Ok(())
          15  +
    /* JsonSerializerGenerator.kt:358 */
   10     16   
}

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

@@ -1,1 +132,197 @@
    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_describe_limits_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::describe_limits::DescribeLimitsOutput, crate::operation::describe_limits::DescribeLimitsError> {
          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::describe_limits::DescribeLimitsError::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::describe_limits::DescribeLimitsError::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::describe_limits::DescribeLimitsError::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::describe_limits::DescribeLimitsError::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::describe_limits::DescribeLimitsError::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::describe_limits::DescribeLimitsError::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::describe_limits::DescribeLimitsError::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::describe_limits::DescribeLimitsError::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   
        }),
   49         -
        _ => crate::operation::describe_limits::DescribeLimitsError::generic(generic),
          68  +
        /* ProtocolParserGenerator.kt:182 */
          69  +
        _ => crate::operation::describe_limits::DescribeLimitsError::generic(generic), /* ProtocolParserGenerator.kt:133 */
   50     70   
    })
          71  +
    /* ProtocolParserGenerator.kt:99 */
   51     72   
}
   52     73   
          74  +
/* RustType.kt:516 */
   53     75   
#[allow(clippy::unnecessary_wraps)]
          76  +
/* ProtocolParserGenerator.kt:71 */
   54     77   
pub fn de_describe_limits_http_response(
   55     78   
    _response_status: u16,
   56     79   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
   57     80   
    _response_body: &[u8],
   58     81   
) -> std::result::Result<crate::operation::describe_limits::DescribeLimitsOutput, crate::operation::describe_limits::DescribeLimitsError> {
          82  +
    /* ProtocolParserGenerator.kt:77 */
   59     83   
    Ok({
          84  +
        /* RustType.kt:516 */
   60     85   
        #[allow(unused_mut)]
          86  +
        /* ProtocolParserGenerator.kt:240 */
   61     87   
        let mut output = crate::operation::describe_limits::builders::DescribeLimitsOutputBuilder::default();
          88  +
        /* ProtocolParserGenerator.kt:247 */
   62     89   
        output = crate::protocol_serde::shape_describe_limits::de_describe_limits(_response_body, output)
   63     90   
            .map_err(crate::operation::describe_limits::DescribeLimitsError::unhandled)?;
          91  +
        /* ClientBuilderInstantiator.kt:56 */
   64     92   
        output.build()
          93  +
        /* ProtocolParserGenerator.kt:77 */
   65     94   
    })
          95  +
    /* ProtocolParserGenerator.kt:71 */
   66     96   
}
   67     97   
          98  +
/* AwsJson.kt:152 */
   68     99   
pub fn ser_describe_limits_input(
   69    100   
    _input: &crate::operation::describe_limits::DescribeLimitsInput,
   70    101   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
         102  +
    /* AwsJson.kt:156 */
   71    103   
    Ok(::aws_smithy_types::body::SdkBody::from("{}"))
         104  +
    /* AwsJson.kt:152 */
   72    105   
}
   73    106   
         107  +
/* JsonParserGenerator.kt:148 */
   74    108   
pub(crate) fn de_describe_limits(
   75    109   
    value: &[u8],
   76    110   
    mut builder: crate::operation::describe_limits::builders::DescribeLimitsOutputBuilder,
   77    111   
) -> ::std::result::Result<
   78    112   
    crate::operation::describe_limits::builders::DescribeLimitsOutputBuilder,
   79    113   
    ::aws_smithy_json::deserialize::error::DeserializeError,
   80    114   
> {
         115  +
    /* JsonParserGenerator.kt:153 */
   81    116   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
   82    117   
    let tokens = &mut tokens_owned;
   83    118   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
         119  +
    /* JsonParserGenerator.kt:684 */
   84    120   
    loop {
         121  +
        /* JsonParserGenerator.kt:685 */
   85    122   
        match tokens.next().transpose()? {
   86         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   87         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
   88         -
                "AccountMaxReadCapacityUnits" => {
   89         -
                    builder = builder.set_account_max_read_capacity_units(
   90         -
                        ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
   91         -
                            .map(i64::try_from)
   92         -
                            .transpose()?,
   93         -
                    );
         123  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
         124  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
         125  +
                /* JsonParserGenerator.kt:260 */
         126  +
                match key.to_unescaped()?.as_ref() {
         127  +
                    /* JsonParserGenerator.kt:262 */
         128  +
                    "AccountMaxReadCapacityUnits" => {
         129  +
                        /* JsonParserGenerator.kt:265 */
         130  +
                        builder = builder.set_account_max_read_capacity_units(
         131  +
                            /* JsonParserGenerator.kt:365 */
         132  +
                            ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
         133  +
                                .map(i64::try_from)
         134  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
         135  +
                        );
         136  +
                        /* JsonParserGenerator.kt:262 */
         137  +
                    }
         138  +
                    /* JsonParserGenerator.kt:262 */
         139  +
                    "AccountMaxWriteCapacityUnits" => {
         140  +
                        /* JsonParserGenerator.kt:265 */
         141  +
                        builder = builder.set_account_max_write_capacity_units(
         142  +
                            /* JsonParserGenerator.kt:365 */
         143  +
                            ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
         144  +
                                .map(i64::try_from)
         145  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
         146  +
                        );
         147  +
                        /* JsonParserGenerator.kt:262 */
         148  +
                    }
         149  +
                    /* JsonParserGenerator.kt:262 */
         150  +
                    "TableMaxReadCapacityUnits" => {
         151  +
                        /* JsonParserGenerator.kt:265 */
         152  +
                        builder = builder.set_table_max_read_capacity_units(
         153  +
                            /* JsonParserGenerator.kt:365 */
         154  +
                            ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
         155  +
                                .map(i64::try_from)
         156  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
         157  +
                        );
         158  +
                        /* JsonParserGenerator.kt:262 */
         159  +
                    }
         160  +
                    /* JsonParserGenerator.kt:262 */
         161  +
                    "TableMaxWriteCapacityUnits" => {
         162  +
                        /* JsonParserGenerator.kt:265 */
         163  +
                        builder = builder.set_table_max_write_capacity_units(
         164  +
                            /* JsonParserGenerator.kt:365 */
         165  +
                            ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
         166  +
                                .map(i64::try_from)
         167  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
         168  +
                        );
         169  +
                        /* JsonParserGenerator.kt:262 */
         170  +
                    }
         171  +
                    /* JsonParserGenerator.kt:290 */
         172  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
   94    173   
                }
   95         -
                "AccountMaxWriteCapacityUnits" => {
   96         -
                    builder = builder.set_account_max_write_capacity_units(
   97         -
                        ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
   98         -
                            .map(i64::try_from)
   99         -
                            .transpose()?,
  100         -
                    );
  101         -
                }
  102         -
                "TableMaxReadCapacityUnits" => {
  103         -
                    builder = builder.set_table_max_read_capacity_units(
  104         -
                        ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
  105         -
                            .map(i64::try_from)
  106         -
                            .transpose()?,
  107         -
                    );
  108         -
                }
  109         -
                "TableMaxWriteCapacityUnits" => {
  110         -
                    builder = builder.set_table_max_write_capacity_units(
  111         -
                        ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
  112         -
                            .map(i64::try_from)
  113         -
                            .transpose()?,
  114         -
                    );
  115         -
                }
  116         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
  117         -
            },
         174  +
                /* JsonParserGenerator.kt:686 */
         175  +
            }
         176  +
            /* JsonParserGenerator.kt:695 */
  118    177   
            other => {
  119    178   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
  120    179   
                    "expected object key or end object, found: {:?}",
  121    180   
                    other
  122    181   
                )))
  123         -
            }
         182  +
            } /* JsonParserGenerator.kt:685 */
  124    183   
        }
         184  +
        /* JsonParserGenerator.kt:684 */
  125    185   
    }
         186  +
    /* JsonParserGenerator.kt:250 */
  126    187   
    if tokens.next().is_some() {
         188  +
        /* JsonParserGenerator.kt:251 */
  127    189   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
  128    190   
            "found more JSON tokens after completing parsing",
  129    191   
        ));
         192  +
        /* JsonParserGenerator.kt:250 */
  130    193   
    }
         194  +
    /* JsonParserGenerator.kt:163 */
  131    195   
    Ok(builder)
         196  +
    /* JsonParserGenerator.kt:148 */
  132    197   
}

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

@@ -1,1 +126,191 @@
    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_describe_table_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::describe_table::DescribeTableOutput, crate::operation::describe_table::DescribeTableError> {
          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::describe_table::DescribeTableError::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::describe_table::DescribeTableError::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::describe_table::DescribeTableError::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::describe_table::DescribeTableError::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::describe_table::DescribeTableError::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::describe_table::DescribeTableError::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::describe_table::DescribeTableError::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::describe_table::DescribeTableError::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   
        "ResourceNotFoundException" => crate::operation::describe_table::DescribeTableError::ResourceNotFoundError({
          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::ResourceNotFoundErrorBuilder::default();
   54         -
                output = crate::protocol_serde::shape_resource_not_found_exception::de_resource_not_found_exception_json_err(_response_body, output)
   55         -
                    .map_err(crate::operation::describe_table::DescribeTableError::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::ResourceNotFoundErrorBuilder::default();
          76  +
                    /* 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::describe_table::DescribeTableError::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   
        }),
   64         -
        _ => crate::operation::describe_table::DescribeTableError::generic(generic),
          89  +
        /* ProtocolParserGenerator.kt:182 */
          90  +
        _ => crate::operation::describe_table::DescribeTableError::generic(generic), /* ProtocolParserGenerator.kt:133 */
   65     91   
    })
          92  +
    /* ProtocolParserGenerator.kt:99 */
   66     93   
}
   67     94   
          95  +
/* RustType.kt:516 */
   68     96   
#[allow(clippy::unnecessary_wraps)]
          97  +
/* ProtocolParserGenerator.kt:71 */
   69     98   
pub fn de_describe_table_http_response(
   70     99   
    _response_status: u16,
   71    100   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
   72    101   
    _response_body: &[u8],
   73    102   
) -> std::result::Result<crate::operation::describe_table::DescribeTableOutput, crate::operation::describe_table::DescribeTableError> {
         103  +
    /* ProtocolParserGenerator.kt:77 */
   74    104   
    Ok({
         105  +
        /* RustType.kt:516 */
   75    106   
        #[allow(unused_mut)]
         107  +
        /* ProtocolParserGenerator.kt:240 */
   76    108   
        let mut output = crate::operation::describe_table::builders::DescribeTableOutputBuilder::default();
         109  +
        /* ProtocolParserGenerator.kt:247 */
   77    110   
        output = crate::protocol_serde::shape_describe_table::de_describe_table(_response_body, output)
   78    111   
            .map_err(crate::operation::describe_table::DescribeTableError::unhandled)?;
         112  +
        /* ClientBuilderInstantiator.kt:56 */
   79    113   
        output.build()
         114  +
        /* ProtocolParserGenerator.kt:77 */
   80    115   
    })
         116  +
    /* ProtocolParserGenerator.kt:71 */
   81    117   
}
   82    118   
         119  +
/* JsonSerializerGenerator.kt:287 */
   83    120   
pub fn ser_describe_table_input(
   84    121   
    input: &crate::operation::describe_table::DescribeTableInput,
   85    122   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
         123  +
    /* JsonSerializerGenerator.kt:291 */
   86    124   
    let mut out = String::new();
         125  +
    /* JsonSerializerGenerator.kt:292 */
   87    126   
    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
         127  +
    /* JsonSerializerGenerator.kt:375 */
   88    128   
    crate::protocol_serde::shape_describe_table_input::ser_describe_table_input_input(&mut object, input)?;
         129  +
    /* JsonSerializerGenerator.kt:295 */
   89    130   
    object.finish();
         131  +
    /* JsonSerializerGenerator.kt:296 */
   90    132   
    Ok(::aws_smithy_types::body::SdkBody::from(out))
         133  +
    /* JsonSerializerGenerator.kt:287 */
   91    134   
}
   92    135   
         136  +
/* JsonParserGenerator.kt:148 */
   93    137   
pub(crate) fn de_describe_table(
   94    138   
    value: &[u8],
   95    139   
    mut builder: crate::operation::describe_table::builders::DescribeTableOutputBuilder,
   96    140   
) -> ::std::result::Result<
   97    141   
    crate::operation::describe_table::builders::DescribeTableOutputBuilder,
   98    142   
    ::aws_smithy_json::deserialize::error::DeserializeError,
   99    143   
> {
         144  +
    /* JsonParserGenerator.kt:153 */
  100    145   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
  101    146   
    let tokens = &mut tokens_owned;
  102    147   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
         148  +
    /* JsonParserGenerator.kt:684 */
  103    149   
    loop {
         150  +
        /* JsonParserGenerator.kt:685 */
  104    151   
        match tokens.next().transpose()? {
  105         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
  106         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
  107         -
                "Table" => {
  108         -
                    builder = builder.set_table(crate::protocol_serde::shape_table_description::de_table_description(tokens)?);
         152  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
         153  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
         154  +
                /* JsonParserGenerator.kt:260 */
         155  +
                match key.to_unescaped()?.as_ref() {
         156  +
                    /* JsonParserGenerator.kt:262 */
         157  +
                    "Table" => {
         158  +
                        /* JsonParserGenerator.kt:265 */
         159  +
                        builder = builder.set_table(
         160  +
                            /* JsonParserGenerator.kt:544 */
         161  +
                            crate::protocol_serde::shape_table_description::de_table_description(tokens)?, /* JsonParserGenerator.kt:265 */
         162  +
                        );
         163  +
                        /* JsonParserGenerator.kt:262 */
         164  +
                    }
         165  +
                    /* JsonParserGenerator.kt:290 */
         166  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
  109    167   
                }
  110         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
  111         -
            },
         168  +
                /* JsonParserGenerator.kt:686 */
         169  +
            }
         170  +
            /* JsonParserGenerator.kt:695 */
  112    171   
            other => {
  113    172   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
  114    173   
                    "expected object key or end object, found: {:?}",
  115    174   
                    other
  116    175   
                )))
  117         -
            }
         176  +
            } /* JsonParserGenerator.kt:685 */
  118    177   
        }
         178  +
        /* JsonParserGenerator.kt:684 */
  119    179   
    }
         180  +
    /* JsonParserGenerator.kt:250 */
  120    181   
    if tokens.next().is_some() {
         182  +
        /* JsonParserGenerator.kt:251 */
  121    183   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
  122    184   
            "found more JSON tokens after completing parsing",
  123    185   
        ));
         186  +
        /* JsonParserGenerator.kt:250 */
  124    187   
    }
         188  +
    /* JsonParserGenerator.kt:163 */
  125    189   
    Ok(builder)
         190  +
    /* JsonParserGenerator.kt:148 */
  126    191   
}

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

@@ -1,1 +10,16 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_describe_table_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::describe_table::DescribeTableInput,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.table_name {
           9  +
        /* JsonSerializerGenerator.kt:423 */
    7     10   
        object.key("TableName").string(var_1.as_str());
          11  +
        /* JsonSerializerGenerator.kt:382 */
    8     12   
    }
          13  +
    /* JsonSerializerGenerator.kt:372 */
    9     14   
    Ok(())
          15  +
    /* JsonSerializerGenerator.kt:358 */
   10     16   
}

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

@@ -1,1 +122,177 @@
    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_describe_table_replica_auto_scaling_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::describe_table_replica_auto_scaling::DescribeTableReplicaAutoScalingOutput,
    9     11   
    crate::operation::describe_table_replica_auto_scaling::DescribeTableReplicaAutoScalingError,
   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::describe_table_replica_auto_scaling::DescribeTableReplicaAutoScalingError::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::describe_table_replica_auto_scaling::DescribeTableReplicaAutoScalingError::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   
        "InternalServerError" => crate::operation::describe_table_replica_auto_scaling::DescribeTableReplicaAutoScalingError::InternalServerError({
          31  +
            /* RustType.kt:516 */
   23     32   
            #[allow(unused_mut)]
   24         -
            let mut tmp = {
   25         -
                #[allow(unused_mut)]
   26         -
                let mut output = crate::types::error::builders::InternalServerErrorBuilder::default();
   27         -
                output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output)
   28         -
                    .map_err(crate::operation::describe_table_replica_auto_scaling::DescribeTableReplicaAutoScalingError::unhandled)?;
   29         -
                let output = output.meta(generic);
   30         -
                output.build()
   31         -
            };
          33  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          34  +
                /* ProtocolParserGenerator.kt:146 */ {
          35  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          36  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::InternalServerErrorBuilder::default();
          37  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output).map_err(crate::operation::describe_table_replica_auto_scaling::DescribeTableReplicaAutoScalingError::unhandled)?;
          38  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          39  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
          40  +
                /* ProtocolParserGenerator.kt:146 */}
          41  +
            /* ProtocolParserGenerator.kt:145 */;
          42  +
            /* ProtocolParserGenerator.kt:170 */
   32     43   
            if tmp.message.is_none() {
   33     44   
                tmp.message = _error_message;
   34     45   
            }
          46  +
            /* ProtocolParserGenerator.kt:179 */
   35     47   
            tmp
          48  +
            /* ProtocolParserGenerator.kt:139 */
   36     49   
        }),
          50  +
        /* ProtocolParserGenerator.kt:139 */
   37     51   
        "ResourceNotFoundException" => {
   38     52   
            crate::operation::describe_table_replica_auto_scaling::DescribeTableReplicaAutoScalingError::ResourceNotFoundError({
          53  +
                /* RustType.kt:516 */
   39     54   
                #[allow(unused_mut)]
   40         -
                let mut tmp = {
   41         -
                    #[allow(unused_mut)]
   42         -
                    let mut output = crate::types::error::builders::ResourceNotFoundErrorBuilder::default();
   43         -
                    output =
   44         -
                        crate::protocol_serde::shape_resource_not_found_exception::de_resource_not_found_exception_json_err(_response_body, output)
   45         -
                            .map_err(crate::operation::describe_table_replica_auto_scaling::DescribeTableReplicaAutoScalingError::unhandled)?;
   46         -
                    let output = output.meta(generic);
   47         -
                    output.build()
   48         -
                };
          55  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          56  +
                /* ProtocolParserGenerator.kt:146 */ {
          57  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          58  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::ResourceNotFoundErrorBuilder::default();
          59  +
                    /* 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::describe_table_replica_auto_scaling::DescribeTableReplicaAutoScalingError::unhandled)?;
          60  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          61  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
          62  +
                /* ProtocolParserGenerator.kt:146 */}
          63  +
            /* ProtocolParserGenerator.kt:145 */;
          64  +
                /* ProtocolParserGenerator.kt:170 */
   49     65   
                if tmp.message.is_none() {
   50     66   
                    tmp.message = _error_message;
   51     67   
                }
          68  +
                /* ProtocolParserGenerator.kt:179 */
   52     69   
                tmp
          70  +
                /* ProtocolParserGenerator.kt:139 */
   53     71   
            })
   54     72   
        }
   55         -
        _ => crate::operation::describe_table_replica_auto_scaling::DescribeTableReplicaAutoScalingError::generic(generic),
          73  +
        /* ProtocolParserGenerator.kt:182 */
          74  +
        _ => crate::operation::describe_table_replica_auto_scaling::DescribeTableReplicaAutoScalingError::generic(generic), /* ProtocolParserGenerator.kt:133 */
   56     75   
    })
          76  +
    /* ProtocolParserGenerator.kt:99 */
   57     77   
}
   58     78   
          79  +
/* RustType.kt:516 */
   59     80   
#[allow(clippy::unnecessary_wraps)]
          81  +
/* ProtocolParserGenerator.kt:71 */
   60     82   
pub fn de_describe_table_replica_auto_scaling_http_response(
   61     83   
    _response_status: u16,
   62     84   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
   63     85   
    _response_body: &[u8],
   64     86   
) -> std::result::Result<
   65     87   
    crate::operation::describe_table_replica_auto_scaling::DescribeTableReplicaAutoScalingOutput,
   66     88   
    crate::operation::describe_table_replica_auto_scaling::DescribeTableReplicaAutoScalingError,
   67     89   
> {
          90  +
    /* ProtocolParserGenerator.kt:77 */
   68     91   
    Ok({
          92  +
        /* RustType.kt:516 */
   69     93   
        #[allow(unused_mut)]
          94  +
        /* ProtocolParserGenerator.kt:240 */
   70     95   
        let mut output = crate::operation::describe_table_replica_auto_scaling::builders::DescribeTableReplicaAutoScalingOutputBuilder::default();
          96  +
        /* ProtocolParserGenerator.kt:247 */
   71     97   
        output = crate::protocol_serde::shape_describe_table_replica_auto_scaling::de_describe_table_replica_auto_scaling(_response_body, output)
   72     98   
            .map_err(crate::operation::describe_table_replica_auto_scaling::DescribeTableReplicaAutoScalingError::unhandled)?;
          99  +
        /* ClientBuilderInstantiator.kt:56 */
   73    100   
        output.build()
         101  +
        /* ProtocolParserGenerator.kt:77 */
   74    102   
    })
         103  +
    /* ProtocolParserGenerator.kt:71 */
   75    104   
}
   76    105   
         106  +
/* JsonSerializerGenerator.kt:287 */
   77    107   
pub fn ser_describe_table_replica_auto_scaling_input(
   78    108   
    input: &crate::operation::describe_table_replica_auto_scaling::DescribeTableReplicaAutoScalingInput,
   79    109   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
         110  +
    /* JsonSerializerGenerator.kt:291 */
   80    111   
    let mut out = String::new();
         112  +
    /* JsonSerializerGenerator.kt:292 */
   81    113   
    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
         114  +
    /* JsonSerializerGenerator.kt:375 */
   82    115   
    crate::protocol_serde::shape_describe_table_replica_auto_scaling_input::ser_describe_table_replica_auto_scaling_input_input(&mut object, input)?;
         116  +
    /* JsonSerializerGenerator.kt:295 */
   83    117   
    object.finish();
         118  +
    /* JsonSerializerGenerator.kt:296 */
   84    119   
    Ok(::aws_smithy_types::body::SdkBody::from(out))
         120  +
    /* JsonSerializerGenerator.kt:287 */
   85    121   
}
   86    122   
         123  +
/* JsonParserGenerator.kt:148 */
   87    124   
pub(crate) fn de_describe_table_replica_auto_scaling(
   88    125   
    value: &[u8],
   89    126   
    mut builder: crate::operation::describe_table_replica_auto_scaling::builders::DescribeTableReplicaAutoScalingOutputBuilder,
   90    127   
) -> ::std::result::Result<
   91    128   
    crate::operation::describe_table_replica_auto_scaling::builders::DescribeTableReplicaAutoScalingOutputBuilder,
   92    129   
    ::aws_smithy_json::deserialize::error::DeserializeError,
   93    130   
> {
         131  +
    /* JsonParserGenerator.kt:153 */
   94    132   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
   95    133   
    let tokens = &mut tokens_owned;
   96    134   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
         135  +
    /* JsonParserGenerator.kt:684 */
   97    136   
    loop {
         137  +
        /* JsonParserGenerator.kt:685 */
   98    138   
        match tokens.next().transpose()? {
   99         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
  100         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
  101         -
                "TableAutoScalingDescription" => {
  102         -
                    builder = builder.set_table_auto_scaling_description(
  103         -
                        crate::protocol_serde::shape_table_auto_scaling_description::de_table_auto_scaling_description(tokens)?,
  104         -
                    );
         139  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
         140  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
         141  +
                /* JsonParserGenerator.kt:260 */
         142  +
                match key.to_unescaped()?.as_ref() {
         143  +
                    /* JsonParserGenerator.kt:262 */
         144  +
                    "TableAutoScalingDescription" => {
         145  +
                        /* JsonParserGenerator.kt:265 */
         146  +
                        builder = builder.set_table_auto_scaling_description(
         147  +
                            /* JsonParserGenerator.kt:544 */crate::protocol_serde::shape_table_auto_scaling_description::de_table_auto_scaling_description(tokens)?
         148  +
                        /* JsonParserGenerator.kt:265 */);
         149  +
                        /* JsonParserGenerator.kt:262 */
         150  +
                    }
         151  +
                    /* JsonParserGenerator.kt:290 */
         152  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
  105    153   
                }
  106         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
  107         -
            },
         154  +
                /* JsonParserGenerator.kt:686 */
         155  +
            }
         156  +
            /* JsonParserGenerator.kt:695 */
  108    157   
            other => {
  109    158   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
  110    159   
                    "expected object key or end object, found: {:?}",
  111    160   
                    other
  112    161   
                )))
  113         -
            }
         162  +
            } /* JsonParserGenerator.kt:685 */
  114    163   
        }
         164  +
        /* JsonParserGenerator.kt:684 */
  115    165   
    }
         166  +
    /* JsonParserGenerator.kt:250 */
  116    167   
    if tokens.next().is_some() {
         168  +
        /* JsonParserGenerator.kt:251 */
  117    169   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
  118    170   
            "found more JSON tokens after completing parsing",
  119    171   
        ));
         172  +
        /* JsonParserGenerator.kt:250 */
  120    173   
    }
         174  +
    /* JsonParserGenerator.kt:163 */
  121    175   
    Ok(builder)
         176  +
    /* JsonParserGenerator.kt:148 */
  122    177   
}