Client Test

Client Test

rev. dfb5149b65b7bcc09edd15b8e071ad43b5ac5943 (ignoring whitespace)

Files changed:

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() {
         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 */
   88    128   
                    "AccountMaxReadCapacityUnits" => {
         129  +
                        /* JsonParserGenerator.kt:265 */
   89    130   
                        builder = builder.set_account_max_read_capacity_units(
         131  +
                            /* JsonParserGenerator.kt:365 */
   90    132   
                            ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
   91    133   
                                .map(i64::try_from)
   92         -
                            .transpose()?,
         134  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
   93    135   
                        );
         136  +
                        /* JsonParserGenerator.kt:262 */
   94    137   
                    }
         138  +
                    /* JsonParserGenerator.kt:262 */
   95    139   
                    "AccountMaxWriteCapacityUnits" => {
         140  +
                        /* JsonParserGenerator.kt:265 */
   96    141   
                        builder = builder.set_account_max_write_capacity_units(
         142  +
                            /* JsonParserGenerator.kt:365 */
   97    143   
                            ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
   98    144   
                                .map(i64::try_from)
   99         -
                            .transpose()?,
         145  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
  100    146   
                        );
         147  +
                        /* JsonParserGenerator.kt:262 */
  101    148   
                    }
         149  +
                    /* JsonParserGenerator.kt:262 */
  102    150   
                    "TableMaxReadCapacityUnits" => {
         151  +
                        /* JsonParserGenerator.kt:265 */
  103    152   
                        builder = builder.set_table_max_read_capacity_units(
         153  +
                            /* JsonParserGenerator.kt:365 */
  104    154   
                            ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
  105    155   
                                .map(i64::try_from)
  106         -
                            .transpose()?,
         156  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
  107    157   
                        );
         158  +
                        /* JsonParserGenerator.kt:262 */
  108    159   
                    }
         160  +
                    /* JsonParserGenerator.kt:262 */
  109    161   
                    "TableMaxWriteCapacityUnits" => {
         162  +
                        /* JsonParserGenerator.kt:265 */
  110    163   
                        builder = builder.set_table_max_write_capacity_units(
         164  +
                            /* JsonParserGenerator.kt:365 */
  111    165   
                            ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
  112    166   
                                .map(i64::try_from)
  113         -
                            .transpose()?,
         167  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
  114    168   
                        );
         169  +
                        /* JsonParserGenerator.kt:262 */
         170  +
                    }
         171  +
                    /* JsonParserGenerator.kt:290 */
         172  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
  115    173   
                }
  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   
                )))
         182  +
            } /* JsonParserGenerator.kt:685 */
  123    183   
        }
         184  +
        /* JsonParserGenerator.kt:684 */
  124    185   
    }
  125         -
    }
         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() {
         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 */
  107    157   
                    "Table" => {
  108         -
                    builder = builder.set_table(crate::protocol_serde::shape_table_description::de_table_description(tokens)?);
         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 */
  109    164   
                    }
  110         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
  111         -
            },
         165  +
                    /* JsonParserGenerator.kt:290 */
         166  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
         167  +
                }
         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   
                )))
         176  +
            } /* JsonParserGenerator.kt:685 */
  117    177   
        }
         178  +
        /* JsonParserGenerator.kt:684 */
  118    179   
    }
  119         -
    }
         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() {
         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 */
  101    144   
                    "TableAutoScalingDescription" => {
         145  +
                        /* JsonParserGenerator.kt:265 */
  102    146   
                        builder = builder.set_table_auto_scaling_description(
  103         -
                        crate::protocol_serde::shape_table_auto_scaling_description::de_table_auto_scaling_description(tokens)?,
  104         -
                    );
         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   
                )))
         162  +
            } /* JsonParserGenerator.kt:685 */
  113    163   
        }
         164  +
        /* JsonParserGenerator.kt:684 */
  114    165   
    }
  115         -
    }
         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   
}

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_describe_table_replica_auto_scaling_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_replica_auto_scaling_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::describe_table_replica_auto_scaling::DescribeTableReplicaAutoScalingInput,
    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_time_to_live.rs

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

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_describe_time_to_live_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_time_to_live_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::describe_time_to_live::DescribeTimeToLiveInput,
    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_disable_kinesis_streaming_destination.rs

@@ -1,1 +195,286 @@
    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_disable_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::disable_kinesis_streaming_destination::DisableKinesisStreamingDestinationOutput,
    9     11   
    crate::operation::disable_kinesis_streaming_destination::DisableKinesisStreamingDestinationError,
   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::disable_kinesis_streaming_destination::DisableKinesisStreamingDestinationError::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::disable_kinesis_streaming_destination::DisableKinesisStreamingDestinationError::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::disable_kinesis_streaming_destination::DisableKinesisStreamingDestinationError::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::disable_kinesis_streaming_destination::DisableKinesisStreamingDestinationError::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::disable_kinesis_streaming_destination::DisableKinesisStreamingDestinationError::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::disable_kinesis_streaming_destination::DisableKinesisStreamingDestinationError::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::disable_kinesis_streaming_destination::DisableKinesisStreamingDestinationError::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::disable_kinesis_streaming_destination::DisableKinesisStreamingDestinationError::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   
        "LimitExceededException" => {
   57     77   
            crate::operation::disable_kinesis_streaming_destination::DisableKinesisStreamingDestinationError::LimitExceededError({
          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::LimitExceededErrorBuilder::default();
   62         -
                    output = crate::protocol_serde::shape_limit_exceeded_exception::de_limit_exceeded_exception_json_err(_response_body, output)
   63         -
                        .map_err(crate::operation::disable_kinesis_streaming_destination::DisableKinesisStreamingDestinationError::unhandled)?;
   64         -
                    let output = output.meta(generic);
   65         -
                    output.build()
   66         -
                };
          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::LimitExceededErrorBuilder::default();
          84  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_limit_exceeded_exception::de_limit_exceeded_exception_json_err(_response_body, output).map_err(crate::operation::disable_kinesis_streaming_destination::DisableKinesisStreamingDestinationError::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 */
   67     90   
                if tmp.message.is_none() {
   68     91   
                    tmp.message = _error_message;
   69     92   
                }
          93  +
                /* ProtocolParserGenerator.kt:179 */
   70     94   
                tmp
          95  +
                /* ProtocolParserGenerator.kt:139 */
   71     96   
            })
   72     97   
        }
          98  +
        /* ProtocolParserGenerator.kt:139 */
   73     99   
        "ResourceInUseException" => {
   74    100   
            crate::operation::disable_kinesis_streaming_destination::DisableKinesisStreamingDestinationError::ResourceInUseError({
         101  +
                /* RustType.kt:516 */
   75    102   
                #[allow(unused_mut)]
   76         -
                let mut tmp = {
   77         -
                    #[allow(unused_mut)]
   78         -
                    let mut output = crate::types::error::builders::ResourceInUseErrorBuilder::default();
   79         -
                    output = crate::protocol_serde::shape_resource_in_use_exception::de_resource_in_use_exception_json_err(_response_body, output)
   80         -
                        .map_err(crate::operation::disable_kinesis_streaming_destination::DisableKinesisStreamingDestinationError::unhandled)?;
   81         -
                    let output = output.meta(generic);
   82         -
                    output.build()
   83         -
                };
         103  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
         104  +
                /* ProtocolParserGenerator.kt:146 */ {
         105  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
         106  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::ResourceInUseErrorBuilder::default();
         107  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_resource_in_use_exception::de_resource_in_use_exception_json_err(_response_body, output).map_err(crate::operation::disable_kinesis_streaming_destination::DisableKinesisStreamingDestinationError::unhandled)?;
         108  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
         109  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
         110  +
                /* ProtocolParserGenerator.kt:146 */}
         111  +
            /* ProtocolParserGenerator.kt:145 */;
         112  +
                /* ProtocolParserGenerator.kt:170 */
   84    113   
                if tmp.message.is_none() {
   85    114   
                    tmp.message = _error_message;
   86    115   
                }
         116  +
                /* ProtocolParserGenerator.kt:179 */
   87    117   
                tmp
         118  +
                /* ProtocolParserGenerator.kt:139 */
   88    119   
            })
   89    120   
        }
         121  +
        /* ProtocolParserGenerator.kt:139 */
   90    122   
        "ResourceNotFoundException" => {
   91    123   
            crate::operation::disable_kinesis_streaming_destination::DisableKinesisStreamingDestinationError::ResourceNotFoundError({
         124  +
                /* RustType.kt:516 */
   92    125   
                #[allow(unused_mut)]
   93         -
                let mut tmp = {
   94         -
                    #[allow(unused_mut)]
   95         -
                    let mut output = crate::types::error::builders::ResourceNotFoundErrorBuilder::default();
   96         -
                    output =
   97         -
                        crate::protocol_serde::shape_resource_not_found_exception::de_resource_not_found_exception_json_err(_response_body, output)
   98         -
                            .map_err(crate::operation::disable_kinesis_streaming_destination::DisableKinesisStreamingDestinationError::unhandled)?;
   99         -
                    let output = output.meta(generic);
  100         -
                    output.build()
  101         -
                };
         126  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
         127  +
                /* ProtocolParserGenerator.kt:146 */ {
         128  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
         129  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::ResourceNotFoundErrorBuilder::default();
         130  +
                    /* 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::disable_kinesis_streaming_destination::DisableKinesisStreamingDestinationError::unhandled)?;
         131  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
         132  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
         133  +
                /* ProtocolParserGenerator.kt:146 */}
         134  +
            /* ProtocolParserGenerator.kt:145 */;
         135  +
                /* ProtocolParserGenerator.kt:170 */
  102    136   
                if tmp.message.is_none() {
  103    137   
                    tmp.message = _error_message;
  104    138   
                }
         139  +
                /* ProtocolParserGenerator.kt:179 */
  105    140   
                tmp
         141  +
                /* ProtocolParserGenerator.kt:139 */
  106    142   
            })
  107    143   
        }
  108         -
        _ => crate::operation::disable_kinesis_streaming_destination::DisableKinesisStreamingDestinationError::generic(generic),
         144  +
        /* ProtocolParserGenerator.kt:182 */
         145  +
        _ => crate::operation::disable_kinesis_streaming_destination::DisableKinesisStreamingDestinationError::generic(generic), /* ProtocolParserGenerator.kt:133 */
  109    146   
    })
         147  +
    /* ProtocolParserGenerator.kt:99 */
  110    148   
}
  111    149   
         150  +
/* RustType.kt:516 */
  112    151   
#[allow(clippy::unnecessary_wraps)]
         152  +
/* ProtocolParserGenerator.kt:71 */
  113    153   
pub fn de_disable_kinesis_streaming_destination_http_response(
  114    154   
    _response_status: u16,
  115    155   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
  116    156   
    _response_body: &[u8],
  117    157   
) -> std::result::Result<
  118    158   
    crate::operation::disable_kinesis_streaming_destination::DisableKinesisStreamingDestinationOutput,
  119    159   
    crate::operation::disable_kinesis_streaming_destination::DisableKinesisStreamingDestinationError,
  120    160   
> {
         161  +
    /* ProtocolParserGenerator.kt:77 */
  121    162   
    Ok({
         163  +
        /* RustType.kt:516 */
  122    164   
        #[allow(unused_mut)]
         165  +
        /* ProtocolParserGenerator.kt:240 */
  123    166   
        let mut output =
  124    167   
            crate::operation::disable_kinesis_streaming_destination::builders::DisableKinesisStreamingDestinationOutputBuilder::default();
         168  +
        /* ProtocolParserGenerator.kt:247 */
  125    169   
        output = crate::protocol_serde::shape_disable_kinesis_streaming_destination::de_disable_kinesis_streaming_destination(_response_body, output)
  126    170   
            .map_err(crate::operation::disable_kinesis_streaming_destination::DisableKinesisStreamingDestinationError::unhandled)?;
         171  +
        /* ClientBuilderInstantiator.kt:56 */
  127    172   
        output.build()
         173  +
        /* ProtocolParserGenerator.kt:77 */
  128    174   
    })
         175  +
    /* ProtocolParserGenerator.kt:71 */
  129    176   
}
  130    177   
         178  +
/* JsonSerializerGenerator.kt:287 */
  131    179   
pub fn ser_disable_kinesis_streaming_destination_input(
  132    180   
    input: &crate::operation::disable_kinesis_streaming_destination::DisableKinesisStreamingDestinationInput,
  133    181   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
         182  +
    /* JsonSerializerGenerator.kt:291 */
  134    183   
    let mut out = String::new();
         184  +
    /* JsonSerializerGenerator.kt:292 */
  135    185   
    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
         186  +
    /* JsonSerializerGenerator.kt:375 */
  136    187   
    crate::protocol_serde::shape_disable_kinesis_streaming_destination_input::ser_disable_kinesis_streaming_destination_input_input(
  137    188   
        &mut object,
  138    189   
        input,
  139    190   
    )?;
         191  +
    /* JsonSerializerGenerator.kt:295 */
  140    192   
    object.finish();
         193  +
    /* JsonSerializerGenerator.kt:296 */
  141    194   
    Ok(::aws_smithy_types::body::SdkBody::from(out))
         195  +
    /* JsonSerializerGenerator.kt:287 */
  142    196   
}
  143    197   
         198  +
/* JsonParserGenerator.kt:148 */
  144    199   
pub(crate) fn de_disable_kinesis_streaming_destination(
  145    200   
    value: &[u8],
  146    201   
    mut builder: crate::operation::disable_kinesis_streaming_destination::builders::DisableKinesisStreamingDestinationOutputBuilder,
  147    202   
) -> ::std::result::Result<
  148    203   
    crate::operation::disable_kinesis_streaming_destination::builders::DisableKinesisStreamingDestinationOutputBuilder,
  149    204   
    ::aws_smithy_json::deserialize::error::DeserializeError,
  150    205   
> {
         206  +
    /* JsonParserGenerator.kt:153 */
  151    207   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
  152    208   
    let tokens = &mut tokens_owned;
  153    209   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
         210  +
    /* JsonParserGenerator.kt:684 */
  154    211   
    loop {
         212  +
        /* JsonParserGenerator.kt:685 */
  155    213   
        match tokens.next().transpose()? {
  156         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
  157         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
         214  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
         215  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
         216  +
                /* JsonParserGenerator.kt:260 */
         217  +
                match key.to_unescaped()?.as_ref() {
         218  +
                    /* JsonParserGenerator.kt:262 */
  158    219   
                    "TableName" => {
         220  +
                        /* JsonParserGenerator.kt:265 */
  159    221   
                        builder = builder.set_table_name(
         222  +
                            /* JsonParserGenerator.kt:354 */
  160    223   
                            ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
  161         -
                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
  162         -
                            .transpose()?,
         224  +
                                .map(|s|
         225  +
                                /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
         226  +
                                    /* JsonParserGenerator.kt:348 */u.into_owned()
         227  +
                                /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
         228  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
  163    229   
                        );
         230  +
                        /* JsonParserGenerator.kt:262 */
  164    231   
                    }
         232  +
                    /* JsonParserGenerator.kt:262 */
  165    233   
                    "StreamArn" => {
         234  +
                        /* JsonParserGenerator.kt:265 */
  166    235   
                        builder = builder.set_stream_arn(
         236  +
                            /* JsonParserGenerator.kt:354 */
  167    237   
                            ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
  168         -
                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
  169         -
                            .transpose()?,
         238  +
                                .map(|s|
         239  +
                                /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
         240  +
                                    /* JsonParserGenerator.kt:348 */u.into_owned()
         241  +
                                /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
         242  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
  170    243   
                        );
         244  +
                        /* JsonParserGenerator.kt:262 */
  171    245   
                    }
         246  +
                    /* JsonParserGenerator.kt:262 */
  172    247   
                    "DestinationStatus" => {
         248  +
                        /* JsonParserGenerator.kt:265 */
  173    249   
                        builder = builder.set_destination_status(
         250  +
                            /* JsonParserGenerator.kt:354 */
  174    251   
                            ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
  175         -
                            .map(|s| s.to_unescaped().map(|u| crate::types::DestinationStatus::from(u.as_ref())))
  176         -
                            .transpose()?,
         252  +
                                .map(|s|
         253  +
                                /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
         254  +
                                    /* JsonParserGenerator.kt:345 */crate::types::DestinationStatus::from(u.as_ref())
         255  +
                                /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
         256  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
  177    257   
                        );
         258  +
                        /* JsonParserGenerator.kt:262 */
         259  +
                    }
         260  +
                    /* JsonParserGenerator.kt:290 */
         261  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
  178    262   
                }
  179         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
  180         -
            },
         263  +
                /* JsonParserGenerator.kt:686 */
         264  +
            }
         265  +
            /* JsonParserGenerator.kt:695 */
  181    266   
            other => {
  182    267   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
  183    268   
                    "expected object key or end object, found: {:?}",
  184    269   
                    other
  185    270   
                )))
         271  +
            } /* JsonParserGenerator.kt:685 */
  186    272   
        }
         273  +
        /* JsonParserGenerator.kt:684 */
  187    274   
    }
  188         -
    }
         275  +
    /* JsonParserGenerator.kt:250 */
  189    276   
    if tokens.next().is_some() {
         277  +
        /* JsonParserGenerator.kt:251 */
  190    278   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
  191    279   
            "found more JSON tokens after completing parsing",
  192    280   
        ));
         281  +
        /* JsonParserGenerator.kt:250 */
  193    282   
    }
         283  +
    /* JsonParserGenerator.kt:163 */
  194    284   
    Ok(builder)
         285  +
    /* JsonParserGenerator.kt:148 */
  195    286   
}

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_disable_kinesis_streaming_destination_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_disable_kinesis_streaming_destination_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::disable_kinesis_streaming_destination::DisableKinesisStreamingDestinationInput,
    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.stream_arn {
          15  +
        /* JsonSerializerGenerator.kt:423 */
   10     16   
        object.key("StreamArn").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_duplicate_item_exception.rs

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

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

@@ -1,1 +194,285 @@
    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_enable_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::enable_kinesis_streaming_destination::EnableKinesisStreamingDestinationOutput,
    9     11   
    crate::operation::enable_kinesis_streaming_destination::EnableKinesisStreamingDestinationError,
   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::enable_kinesis_streaming_destination::EnableKinesisStreamingDestinationError::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::enable_kinesis_streaming_destination::EnableKinesisStreamingDestinationError::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::enable_kinesis_streaming_destination::EnableKinesisStreamingDestinationError::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::enable_kinesis_streaming_destination::EnableKinesisStreamingDestinationError::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::enable_kinesis_streaming_destination::EnableKinesisStreamingDestinationError::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::enable_kinesis_streaming_destination::EnableKinesisStreamingDestinationError::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::enable_kinesis_streaming_destination::EnableKinesisStreamingDestinationError::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::enable_kinesis_streaming_destination::EnableKinesisStreamingDestinationError::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   
        "LimitExceededException" => {
   57     77   
            crate::operation::enable_kinesis_streaming_destination::EnableKinesisStreamingDestinationError::LimitExceededError({
          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::LimitExceededErrorBuilder::default();
   62         -
                    output = crate::protocol_serde::shape_limit_exceeded_exception::de_limit_exceeded_exception_json_err(_response_body, output)
   63         -
                        .map_err(crate::operation::enable_kinesis_streaming_destination::EnableKinesisStreamingDestinationError::unhandled)?;
   64         -
                    let output = output.meta(generic);
   65         -
                    output.build()
   66         -
                };
          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::LimitExceededErrorBuilder::default();
          84  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_limit_exceeded_exception::de_limit_exceeded_exception_json_err(_response_body, output).map_err(crate::operation::enable_kinesis_streaming_destination::EnableKinesisStreamingDestinationError::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 */
   67     90   
                if tmp.message.is_none() {
   68     91   
                    tmp.message = _error_message;
   69     92   
                }
          93  +
                /* ProtocolParserGenerator.kt:179 */
   70     94   
                tmp
          95  +
                /* ProtocolParserGenerator.kt:139 */
   71     96   
            })
   72     97   
        }
          98  +
        /* ProtocolParserGenerator.kt:139 */
   73     99   
        "ResourceInUseException" => {
   74    100   
            crate::operation::enable_kinesis_streaming_destination::EnableKinesisStreamingDestinationError::ResourceInUseError({
         101  +
                /* RustType.kt:516 */
   75    102   
                #[allow(unused_mut)]
   76         -
                let mut tmp = {
   77         -
                    #[allow(unused_mut)]
   78         -
                    let mut output = crate::types::error::builders::ResourceInUseErrorBuilder::default();
   79         -
                    output = crate::protocol_serde::shape_resource_in_use_exception::de_resource_in_use_exception_json_err(_response_body, output)
   80         -
                        .map_err(crate::operation::enable_kinesis_streaming_destination::EnableKinesisStreamingDestinationError::unhandled)?;
   81         -
                    let output = output.meta(generic);
   82         -
                    output.build()
   83         -
                };
         103  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
         104  +
                /* ProtocolParserGenerator.kt:146 */ {
         105  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
         106  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::ResourceInUseErrorBuilder::default();
         107  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_resource_in_use_exception::de_resource_in_use_exception_json_err(_response_body, output).map_err(crate::operation::enable_kinesis_streaming_destination::EnableKinesisStreamingDestinationError::unhandled)?;
         108  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
         109  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
         110  +
                /* ProtocolParserGenerator.kt:146 */}
         111  +
            /* ProtocolParserGenerator.kt:145 */;
         112  +
                /* ProtocolParserGenerator.kt:170 */
   84    113   
                if tmp.message.is_none() {
   85    114   
                    tmp.message = _error_message;
   86    115   
                }
         116  +
                /* ProtocolParserGenerator.kt:179 */
   87    117   
                tmp
         118  +
                /* ProtocolParserGenerator.kt:139 */
   88    119   
            })
   89    120   
        }
         121  +
        /* ProtocolParserGenerator.kt:139 */
   90    122   
        "ResourceNotFoundException" => {
   91    123   
            crate::operation::enable_kinesis_streaming_destination::EnableKinesisStreamingDestinationError::ResourceNotFoundError({
         124  +
                /* RustType.kt:516 */
   92    125   
                #[allow(unused_mut)]
   93         -
                let mut tmp = {
   94         -
                    #[allow(unused_mut)]
   95         -
                    let mut output = crate::types::error::builders::ResourceNotFoundErrorBuilder::default();
   96         -
                    output =
   97         -
                        crate::protocol_serde::shape_resource_not_found_exception::de_resource_not_found_exception_json_err(_response_body, output)
   98         -
                            .map_err(crate::operation::enable_kinesis_streaming_destination::EnableKinesisStreamingDestinationError::unhandled)?;
   99         -
                    let output = output.meta(generic);
  100         -
                    output.build()
  101         -
                };
         126  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
         127  +
                /* ProtocolParserGenerator.kt:146 */ {
         128  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
         129  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::ResourceNotFoundErrorBuilder::default();
         130  +
                    /* 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::enable_kinesis_streaming_destination::EnableKinesisStreamingDestinationError::unhandled)?;
         131  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
         132  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
         133  +
                /* ProtocolParserGenerator.kt:146 */}
         134  +
            /* ProtocolParserGenerator.kt:145 */;
         135  +
                /* ProtocolParserGenerator.kt:170 */
  102    136   
                if tmp.message.is_none() {
  103    137   
                    tmp.message = _error_message;
  104    138   
                }
         139  +
                /* ProtocolParserGenerator.kt:179 */
  105    140   
                tmp
         141  +
                /* ProtocolParserGenerator.kt:139 */
  106    142   
            })
  107    143   
        }
  108         -
        _ => crate::operation::enable_kinesis_streaming_destination::EnableKinesisStreamingDestinationError::generic(generic),
         144  +
        /* ProtocolParserGenerator.kt:182 */
         145  +
        _ => crate::operation::enable_kinesis_streaming_destination::EnableKinesisStreamingDestinationError::generic(generic), /* ProtocolParserGenerator.kt:133 */
  109    146   
    })
         147  +
    /* ProtocolParserGenerator.kt:99 */
  110    148   
}
  111    149   
         150  +
/* RustType.kt:516 */
  112    151   
#[allow(clippy::unnecessary_wraps)]
         152  +
/* ProtocolParserGenerator.kt:71 */
  113    153   
pub fn de_enable_kinesis_streaming_destination_http_response(
  114    154   
    _response_status: u16,
  115    155   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
  116    156   
    _response_body: &[u8],
  117    157   
) -> std::result::Result<
  118    158   
    crate::operation::enable_kinesis_streaming_destination::EnableKinesisStreamingDestinationOutput,
  119    159   
    crate::operation::enable_kinesis_streaming_destination::EnableKinesisStreamingDestinationError,
  120    160   
> {
         161  +
    /* ProtocolParserGenerator.kt:77 */
  121    162   
    Ok({
         163  +
        /* RustType.kt:516 */
  122    164   
        #[allow(unused_mut)]
         165  +
        /* ProtocolParserGenerator.kt:240 */
  123    166   
        let mut output = crate::operation::enable_kinesis_streaming_destination::builders::EnableKinesisStreamingDestinationOutputBuilder::default();
         167  +
        /* ProtocolParserGenerator.kt:247 */
  124    168   
        output = crate::protocol_serde::shape_enable_kinesis_streaming_destination::de_enable_kinesis_streaming_destination(_response_body, output)
  125    169   
            .map_err(crate::operation::enable_kinesis_streaming_destination::EnableKinesisStreamingDestinationError::unhandled)?;
         170  +
        /* ClientBuilderInstantiator.kt:56 */
  126    171   
        output.build()
         172  +
        /* ProtocolParserGenerator.kt:77 */
  127    173   
    })
         174  +
    /* ProtocolParserGenerator.kt:71 */
  128    175   
}
  129    176   
         177  +
/* JsonSerializerGenerator.kt:287 */
  130    178   
pub fn ser_enable_kinesis_streaming_destination_input(
  131    179   
    input: &crate::operation::enable_kinesis_streaming_destination::EnableKinesisStreamingDestinationInput,
  132    180   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
         181  +
    /* JsonSerializerGenerator.kt:291 */
  133    182   
    let mut out = String::new();
         183  +
    /* JsonSerializerGenerator.kt:292 */
  134    184   
    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
         185  +
    /* JsonSerializerGenerator.kt:375 */
  135    186   
    crate::protocol_serde::shape_enable_kinesis_streaming_destination_input::ser_enable_kinesis_streaming_destination_input_input(
  136    187   
        &mut object,
  137    188   
        input,
  138    189   
    )?;
         190  +
    /* JsonSerializerGenerator.kt:295 */
  139    191   
    object.finish();
         192  +
    /* JsonSerializerGenerator.kt:296 */
  140    193   
    Ok(::aws_smithy_types::body::SdkBody::from(out))
         194  +
    /* JsonSerializerGenerator.kt:287 */
  141    195   
}
  142    196   
         197  +
/* JsonParserGenerator.kt:148 */
  143    198   
pub(crate) fn de_enable_kinesis_streaming_destination(
  144    199   
    value: &[u8],
  145    200   
    mut builder: crate::operation::enable_kinesis_streaming_destination::builders::EnableKinesisStreamingDestinationOutputBuilder,
  146    201   
) -> ::std::result::Result<
  147    202   
    crate::operation::enable_kinesis_streaming_destination::builders::EnableKinesisStreamingDestinationOutputBuilder,
  148    203   
    ::aws_smithy_json::deserialize::error::DeserializeError,
  149    204   
> {
         205  +
    /* JsonParserGenerator.kt:153 */
  150    206   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
  151    207   
    let tokens = &mut tokens_owned;
  152    208   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
         209  +
    /* JsonParserGenerator.kt:684 */
  153    210   
    loop {
         211  +
        /* JsonParserGenerator.kt:685 */
  154    212   
        match tokens.next().transpose()? {
  155         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
  156         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
         213  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
         214  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
         215  +
                /* JsonParserGenerator.kt:260 */
         216  +
                match key.to_unescaped()?.as_ref() {
         217  +
                    /* JsonParserGenerator.kt:262 */
  157    218   
                    "TableName" => {
         219  +
                        /* JsonParserGenerator.kt:265 */
  158    220   
                        builder = builder.set_table_name(
         221  +
                            /* JsonParserGenerator.kt:354 */
  159    222   
                            ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
  160         -
                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
  161         -
                            .transpose()?,
         223  +
                                .map(|s|
         224  +
                                /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
         225  +
                                    /* JsonParserGenerator.kt:348 */u.into_owned()
         226  +
                                /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
         227  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
  162    228   
                        );
         229  +
                        /* JsonParserGenerator.kt:262 */
  163    230   
                    }
         231  +
                    /* JsonParserGenerator.kt:262 */
  164    232   
                    "StreamArn" => {
         233  +
                        /* JsonParserGenerator.kt:265 */
  165    234   
                        builder = builder.set_stream_arn(
         235  +
                            /* JsonParserGenerator.kt:354 */
  166    236   
                            ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
  167         -
                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
  168         -
                            .transpose()?,
         237  +
                                .map(|s|
         238  +
                                /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
         239  +
                                    /* JsonParserGenerator.kt:348 */u.into_owned()
         240  +
                                /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
         241  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
  169    242   
                        );
         243  +
                        /* JsonParserGenerator.kt:262 */
  170    244   
                    }
         245  +
                    /* JsonParserGenerator.kt:262 */
  171    246   
                    "DestinationStatus" => {
         247  +
                        /* JsonParserGenerator.kt:265 */
  172    248   
                        builder = builder.set_destination_status(
         249  +
                            /* JsonParserGenerator.kt:354 */
  173    250   
                            ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
  174         -
                            .map(|s| s.to_unescaped().map(|u| crate::types::DestinationStatus::from(u.as_ref())))
  175         -
                            .transpose()?,
         251  +
                                .map(|s|
         252  +
                                /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
         253  +
                                    /* JsonParserGenerator.kt:345 */crate::types::DestinationStatus::from(u.as_ref())
         254  +
                                /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
         255  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
  176    256   
                        );
         257  +
                        /* JsonParserGenerator.kt:262 */
         258  +
                    }
         259  +
                    /* JsonParserGenerator.kt:290 */
         260  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
  177    261   
                }
  178         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
  179         -
            },
         262  +
                /* JsonParserGenerator.kt:686 */
         263  +
            }
         264  +
            /* JsonParserGenerator.kt:695 */
  180    265   
            other => {
  181    266   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
  182    267   
                    "expected object key or end object, found: {:?}",
  183    268   
                    other
  184    269   
                )))
         270  +
            } /* JsonParserGenerator.kt:685 */
  185    271   
        }
         272  +
        /* JsonParserGenerator.kt:684 */
  186    273   
    }
  187         -
    }
         274  +
    /* JsonParserGenerator.kt:250 */
  188    275   
    if tokens.next().is_some() {
         276  +
        /* JsonParserGenerator.kt:251 */
  189    277   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
  190    278   
            "found more JSON tokens after completing parsing",
  191    279   
        ));
         280  +
        /* JsonParserGenerator.kt:250 */
  192    281   
    }
         282  +
    /* JsonParserGenerator.kt:163 */
  193    283   
    Ok(builder)
         284  +
    /* JsonParserGenerator.kt:148 */
  194    285   
}

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_enable_kinesis_streaming_destination_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_enable_kinesis_streaming_destination_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::enable_kinesis_streaming_destination::EnableKinesisStreamingDestinationInput,
    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.stream_arn {
          15  +
        /* JsonSerializerGenerator.kt:423 */
   10     16   
        object.key("StreamArn").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_endpoint.rs

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