Client Test

Client Test

rev. dfb5149b65b7bcc09edd15b8e071ad43b5ac5943 (ignoring whitespace)

Files changed:

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_delete_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_delete_table_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::delete_table::DeleteTableInput,
    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_backup.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_backup_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_backup::DescribeBackupOutput, crate::operation::describe_backup::DescribeBackupError> {
          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_backup::DescribeBackupError::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_backup::DescribeBackupError::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   
        "BackupNotFoundException" => crate::operation::describe_backup::DescribeBackupError::BackupNotFoundError({
          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::BackupNotFoundErrorBuilder::default();
   24         -
                output = crate::protocol_serde::shape_backup_not_found_exception::de_backup_not_found_exception_json_err(_response_body, output)
   25         -
                    .map_err(crate::operation::describe_backup::DescribeBackupError::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::BackupNotFoundErrorBuilder::default();
          34  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_backup_not_found_exception::de_backup_not_found_exception_json_err(_response_body, output).map_err(crate::operation::describe_backup::DescribeBackupError::unhandled)?;
          35  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          36  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
          37  +
                /* ProtocolParserGenerator.kt:146 */}
          38  +
            /* ProtocolParserGenerator.kt:145 */;
          39  +
            /* ProtocolParserGenerator.kt:170 */
   29     40   
            if tmp.message.is_none() {
   30     41   
                tmp.message = _error_message;
   31     42   
            }
          43  +
            /* ProtocolParserGenerator.kt:179 */
   32     44   
            tmp
          45  +
            /* ProtocolParserGenerator.kt:139 */
   33     46   
        }),
          47  +
        /* ProtocolParserGenerator.kt:139 */
   34     48   
        "InternalServerError" => crate::operation::describe_backup::DescribeBackupError::InternalServerError({
          49  +
            /* RustType.kt:516 */
   35     50   
            #[allow(unused_mut)]
   36         -
            let mut tmp = {
   37         -
                #[allow(unused_mut)]
   38         -
                let mut output = crate::types::error::builders::InternalServerErrorBuilder::default();
   39         -
                output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output)
   40         -
                    .map_err(crate::operation::describe_backup::DescribeBackupError::unhandled)?;
   41         -
                let output = output.meta(generic);
   42         -
                output.build()
   43         -
            };
          51  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          52  +
                /* ProtocolParserGenerator.kt:146 */ {
          53  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          54  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::InternalServerErrorBuilder::default();
          55  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output).map_err(crate::operation::describe_backup::DescribeBackupError::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   
        "InvalidEndpointException" => crate::operation::describe_backup::DescribeBackupError::InvalidEndpointError({
          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::InvalidEndpointErrorBuilder::default();
   54         -
                output = crate::protocol_serde::shape_invalid_endpoint_exception::de_invalid_endpoint_exception_json_err(_response_body, output)
   55         -
                    .map_err(crate::operation::describe_backup::DescribeBackupError::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::InvalidEndpointErrorBuilder::default();
          76  +
                    /* 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_backup::DescribeBackupError::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_backup::DescribeBackupError::generic(generic),
          89  +
        /* ProtocolParserGenerator.kt:182 */
          90  +
        _ => crate::operation::describe_backup::DescribeBackupError::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_backup_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_backup::DescribeBackupOutput, crate::operation::describe_backup::DescribeBackupError> {
         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_backup::builders::DescribeBackupOutputBuilder::default();
         109  +
        /* ProtocolParserGenerator.kt:247 */
   77    110   
        output = crate::protocol_serde::shape_describe_backup::de_describe_backup(_response_body, output)
   78    111   
            .map_err(crate::operation::describe_backup::DescribeBackupError::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_backup_input(
   84    121   
    input: &crate::operation::describe_backup::DescribeBackupInput,
   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_backup_input::ser_describe_backup_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_backup(
   94    138   
    value: &[u8],
   95    139   
    mut builder: crate::operation::describe_backup::builders::DescribeBackupOutputBuilder,
   96    140   
) -> ::std::result::Result<
   97    141   
    crate::operation::describe_backup::builders::DescribeBackupOutputBuilder,
   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   
                    "BackupDescription" => {
  108         -
                    builder = builder.set_backup_description(crate::protocol_serde::shape_backup_description::de_backup_description(tokens)?);
         158  +
                        /* JsonParserGenerator.kt:265 */
         159  +
                        builder = builder.set_backup_description(
         160  +
                            /* JsonParserGenerator.kt:544 */
         161  +
                            crate::protocol_serde::shape_backup_description::de_backup_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_backup_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_backup_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::describe_backup::DescribeBackupInput,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.backup_arn {
           9  +
        /* JsonSerializerGenerator.kt:423 */
    7     10   
        object.key("BackupArn").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_continuous_backups.rs

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

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_describe_continuous_backups_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_continuous_backups_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::describe_continuous_backups::DescribeContinuousBackupsInput,
    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_contributor_insights.rs

@@ -1,1 +149,238 @@
    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_contributor_insights_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_contributor_insights::DescribeContributorInsightsOutput,
    9     11   
    crate::operation::describe_contributor_insights::DescribeContributorInsightsError,
   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_contributor_insights::DescribeContributorInsightsError::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_contributor_insights::DescribeContributorInsightsError::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_contributor_insights::DescribeContributorInsightsError::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_contributor_insights::DescribeContributorInsightsError::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_contributor_insights::DescribeContributorInsightsError::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" => crate::operation::describe_contributor_insights::DescribeContributorInsightsError::ResourceNotFoundError({
          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::ResourceNotFoundErrorBuilder::default();
   42         -
                output = crate::protocol_serde::shape_resource_not_found_exception::de_resource_not_found_exception_json_err(_response_body, output)
   43         -
                    .map_err(crate::operation::describe_contributor_insights::DescribeContributorInsightsError::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::ResourceNotFoundErrorBuilder::default();
          58  +
                    /* 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_contributor_insights::DescribeContributorInsightsError::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   
        }),
   52         -
        _ => crate::operation::describe_contributor_insights::DescribeContributorInsightsError::generic(generic),
          71  +
        /* ProtocolParserGenerator.kt:182 */
          72  +
        _ => crate::operation::describe_contributor_insights::DescribeContributorInsightsError::generic(generic), /* ProtocolParserGenerator.kt:133 */
   53     73   
    })
          74  +
    /* ProtocolParserGenerator.kt:99 */
   54     75   
}
   55     76   
          77  +
/* RustType.kt:516 */
   56     78   
#[allow(clippy::unnecessary_wraps)]
          79  +
/* ProtocolParserGenerator.kt:71 */
   57     80   
pub fn de_describe_contributor_insights_http_response(
   58     81   
    _response_status: u16,
   59     82   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
   60     83   
    _response_body: &[u8],
   61     84   
) -> std::result::Result<
   62     85   
    crate::operation::describe_contributor_insights::DescribeContributorInsightsOutput,
   63     86   
    crate::operation::describe_contributor_insights::DescribeContributorInsightsError,
   64     87   
> {
          88  +
    /* ProtocolParserGenerator.kt:77 */
   65     89   
    Ok({
          90  +
        /* RustType.kt:516 */
   66     91   
        #[allow(unused_mut)]
          92  +
        /* ProtocolParserGenerator.kt:240 */
   67     93   
        let mut output = crate::operation::describe_contributor_insights::builders::DescribeContributorInsightsOutputBuilder::default();
          94  +
        /* ProtocolParserGenerator.kt:247 */
   68     95   
        output = crate::protocol_serde::shape_describe_contributor_insights::de_describe_contributor_insights(_response_body, output)
   69     96   
            .map_err(crate::operation::describe_contributor_insights::DescribeContributorInsightsError::unhandled)?;
          97  +
        /* ClientBuilderInstantiator.kt:56 */
   70     98   
        output.build()
          99  +
        /* ProtocolParserGenerator.kt:77 */
   71    100   
    })
         101  +
    /* ProtocolParserGenerator.kt:71 */
   72    102   
}
   73    103   
         104  +
/* JsonSerializerGenerator.kt:287 */
   74    105   
pub fn ser_describe_contributor_insights_input(
   75    106   
    input: &crate::operation::describe_contributor_insights::DescribeContributorInsightsInput,
   76    107   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
         108  +
    /* JsonSerializerGenerator.kt:291 */
   77    109   
    let mut out = String::new();
         110  +
    /* JsonSerializerGenerator.kt:292 */
   78    111   
    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
         112  +
    /* JsonSerializerGenerator.kt:375 */
   79    113   
    crate::protocol_serde::shape_describe_contributor_insights_input::ser_describe_contributor_insights_input_input(&mut object, input)?;
         114  +
    /* JsonSerializerGenerator.kt:295 */
   80    115   
    object.finish();
         116  +
    /* JsonSerializerGenerator.kt:296 */
   81    117   
    Ok(::aws_smithy_types::body::SdkBody::from(out))
         118  +
    /* JsonSerializerGenerator.kt:287 */
   82    119   
}
   83    120   
         121  +
/* JsonParserGenerator.kt:148 */
   84    122   
pub(crate) fn de_describe_contributor_insights(
   85    123   
    value: &[u8],
   86    124   
    mut builder: crate::operation::describe_contributor_insights::builders::DescribeContributorInsightsOutputBuilder,
   87    125   
) -> ::std::result::Result<
   88    126   
    crate::operation::describe_contributor_insights::builders::DescribeContributorInsightsOutputBuilder,
   89    127   
    ::aws_smithy_json::deserialize::error::DeserializeError,
   90    128   
> {
         129  +
    /* JsonParserGenerator.kt:153 */
   91    130   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
   92    131   
    let tokens = &mut tokens_owned;
   93    132   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
         133  +
    /* JsonParserGenerator.kt:684 */
   94    134   
    loop {
         135  +
        /* JsonParserGenerator.kt:685 */
   95    136   
        match tokens.next().transpose()? {
   96         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   97         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
         137  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
         138  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
         139  +
                /* JsonParserGenerator.kt:260 */
         140  +
                match key.to_unescaped()?.as_ref() {
         141  +
                    /* JsonParserGenerator.kt:262 */
   98    142   
                    "TableName" => {
         143  +
                        /* JsonParserGenerator.kt:265 */
   99    144   
                        builder = builder.set_table_name(
         145  +
                            /* JsonParserGenerator.kt:354 */
  100    146   
                            ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
  101         -
                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
  102         -
                            .transpose()?,
         147  +
                                .map(|s|
         148  +
                                /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
         149  +
                                    /* JsonParserGenerator.kt:348 */u.into_owned()
         150  +
                                /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
         151  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
  103    152   
                        );
         153  +
                        /* JsonParserGenerator.kt:262 */
  104    154   
                    }
         155  +
                    /* JsonParserGenerator.kt:262 */
  105    156   
                    "IndexName" => {
         157  +
                        /* JsonParserGenerator.kt:265 */
  106    158   
                        builder = builder.set_index_name(
         159  +
                            /* JsonParserGenerator.kt:354 */
  107    160   
                            ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
  108         -
                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
  109         -
                            .transpose()?,
         161  +
                                .map(|s|
         162  +
                                /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
         163  +
                                    /* JsonParserGenerator.kt:348 */u.into_owned()
         164  +
                                /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
         165  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
  110    166   
                        );
         167  +
                        /* JsonParserGenerator.kt:262 */
  111    168   
                    }
         169  +
                    /* JsonParserGenerator.kt:262 */
  112    170   
                    "ContributorInsightsRuleList" => {
         171  +
                        /* JsonParserGenerator.kt:265 */
  113    172   
                        builder = builder.set_contributor_insights_rule_list(
  114         -
                        crate::protocol_serde::shape_contributor_insights_rule_list::de_contributor_insights_rule_list(tokens)?,
  115         -
                    );
         173  +
                            /* JsonParserGenerator.kt:451 */crate::protocol_serde::shape_contributor_insights_rule_list::de_contributor_insights_rule_list(tokens)?
         174  +
                        /* JsonParserGenerator.kt:265 */);
         175  +
                        /* JsonParserGenerator.kt:262 */
  116    176   
                    }
         177  +
                    /* JsonParserGenerator.kt:262 */
  117    178   
                    "ContributorInsightsStatus" => {
         179  +
                        /* JsonParserGenerator.kt:265 */
  118    180   
                        builder = builder.set_contributor_insights_status(
         181  +
                            /* JsonParserGenerator.kt:354 */
  119    182   
                            ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
  120         -
                            .map(|s| s.to_unescaped().map(|u| crate::types::ContributorInsightsStatus::from(u.as_ref())))
  121         -
                            .transpose()?,
         183  +
                                .map(|s|
         184  +
                                /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
         185  +
                                    /* JsonParserGenerator.kt:345 */crate::types::ContributorInsightsStatus::from(u.as_ref())
         186  +
                                /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
         187  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
  122    188   
                        );
         189  +
                        /* JsonParserGenerator.kt:262 */
  123    190   
                    }
         191  +
                    /* JsonParserGenerator.kt:262 */
  124    192   
                    "LastUpdateDateTime" => {
  125         -
                    builder = builder.set_last_update_date_time(::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
         193  +
                        /* JsonParserGenerator.kt:265 */
         194  +
                        builder = builder.set_last_update_date_time(
         195  +
                            /* JsonParserGenerator.kt:384 */
         196  +
                            ::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
  126    197   
                                tokens.next(),
  127    198   
                                ::aws_smithy_types::date_time::Format::EpochSeconds,
  128         -
                    )?);
         199  +
                            )?, /* JsonParserGenerator.kt:265 */
         200  +
                        );
         201  +
                        /* JsonParserGenerator.kt:262 */
  129    202   
                    }
         203  +
                    /* JsonParserGenerator.kt:262 */
  130    204   
                    "FailureException" => {
  131         -
                    builder = builder.set_failure_exception(crate::protocol_serde::shape_failure_exception::de_failure_exception(tokens)?);
         205  +
                        /* JsonParserGenerator.kt:265 */
         206  +
                        builder = builder.set_failure_exception(
         207  +
                            /* JsonParserGenerator.kt:544 */
         208  +
                            crate::protocol_serde::shape_failure_exception::de_failure_exception(tokens)?, /* JsonParserGenerator.kt:265 */
         209  +
                        );
         210  +
                        /* JsonParserGenerator.kt:262 */
  132    211   
                    }
  133         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
  134         -
            },
         212  +
                    /* JsonParserGenerator.kt:290 */
         213  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
         214  +
                }
         215  +
                /* JsonParserGenerator.kt:686 */
         216  +
            }
         217  +
            /* JsonParserGenerator.kt:695 */
  135    218   
            other => {
  136    219   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
  137    220   
                    "expected object key or end object, found: {:?}",
  138    221   
                    other
  139    222   
                )))
         223  +
            } /* JsonParserGenerator.kt:685 */
  140    224   
        }
         225  +
        /* JsonParserGenerator.kt:684 */
  141    226   
    }
  142         -
    }
         227  +
    /* JsonParserGenerator.kt:250 */
  143    228   
    if tokens.next().is_some() {
         229  +
        /* JsonParserGenerator.kt:251 */
  144    230   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
  145    231   
            "found more JSON tokens after completing parsing",
  146    232   
        ));
         233  +
        /* JsonParserGenerator.kt:250 */
  147    234   
    }
         235  +
    /* JsonParserGenerator.kt:163 */
  148    236   
    Ok(builder)
         237  +
    /* JsonParserGenerator.kt:148 */
  149    238   
}

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

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

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

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

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

@@ -1,1 +126,191 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* RustType.kt:516 */
    2      3   
#[allow(clippy::unnecessary_wraps)]
           4  +
/* ProtocolParserGenerator.kt:99 */
    3      5   
pub fn de_describe_export_http_error(
    4      6   
    _response_status: u16,
    5      7   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
    6      8   
    _response_body: &[u8],
    7      9   
) -> std::result::Result<crate::operation::describe_export::DescribeExportOutput, crate::operation::describe_export::DescribeExportError> {
          10  +
    /* RustType.kt:516 */
    8     11   
    #[allow(unused_mut)]
          12  +
    /* ProtocolParserGenerator.kt:106 */
    9     13   
    let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(_response_status, _response_headers, _response_body)
   10     14   
        .map_err(crate::operation::describe_export::DescribeExportError::unhandled)?;
          15  +
    /* ProtocolParserGenerator.kt:120 */
   11     16   
    let generic = generic_builder.build();
          17  +
    /* ProtocolParserGenerator.kt:122 */
   12     18   
    let error_code = match generic.code() {
   13     19   
        Some(code) => code,
   14     20   
        None => return Err(crate::operation::describe_export::DescribeExportError::unhandled(generic)),
   15     21   
    };
   16     22   
   17     23   
    let _error_message = generic.message().map(|msg| msg.to_owned());
          24  +
    /* ProtocolParserGenerator.kt:133 */
   18     25   
    Err(match error_code {
          26  +
        /* ProtocolParserGenerator.kt:139 */
   19     27   
        "ExportNotFoundException" => crate::operation::describe_export::DescribeExportError::ExportNotFoundError({
          28  +
            /* RustType.kt:516 */
   20     29   
            #[allow(unused_mut)]
   21         -
            let mut tmp = {
   22         -
                #[allow(unused_mut)]
   23         -
                let mut output = crate::types::error::builders::ExportNotFoundErrorBuilder::default();
   24         -
                output = crate::protocol_serde::shape_export_not_found_exception::de_export_not_found_exception_json_err(_response_body, output)
   25         -
                    .map_err(crate::operation::describe_export::DescribeExportError::unhandled)?;
   26         -
                let output = output.meta(generic);
   27         -
                output.build()
   28         -
            };
          30  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          31  +
                /* ProtocolParserGenerator.kt:146 */ {
          32  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          33  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::ExportNotFoundErrorBuilder::default();
          34  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_export_not_found_exception::de_export_not_found_exception_json_err(_response_body, output).map_err(crate::operation::describe_export::DescribeExportError::unhandled)?;
          35  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          36  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
          37  +
                /* ProtocolParserGenerator.kt:146 */}
          38  +
            /* ProtocolParserGenerator.kt:145 */;
          39  +
            /* ProtocolParserGenerator.kt:170 */
   29     40   
            if tmp.message.is_none() {
   30     41   
                tmp.message = _error_message;
   31     42   
            }
          43  +
            /* ProtocolParserGenerator.kt:179 */
   32     44   
            tmp
          45  +
            /* ProtocolParserGenerator.kt:139 */
   33     46   
        }),
          47  +
        /* ProtocolParserGenerator.kt:139 */
   34     48   
        "InternalServerError" => crate::operation::describe_export::DescribeExportError::InternalServerError({
          49  +
            /* RustType.kt:516 */
   35     50   
            #[allow(unused_mut)]
   36         -
            let mut tmp = {
   37         -
                #[allow(unused_mut)]
   38         -
                let mut output = crate::types::error::builders::InternalServerErrorBuilder::default();
   39         -
                output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output)
   40         -
                    .map_err(crate::operation::describe_export::DescribeExportError::unhandled)?;
   41         -
                let output = output.meta(generic);
   42         -
                output.build()
   43         -
            };
          51  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          52  +
                /* ProtocolParserGenerator.kt:146 */ {
          53  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          54  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::InternalServerErrorBuilder::default();
          55  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output).map_err(crate::operation::describe_export::DescribeExportError::unhandled)?;
          56  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          57  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
          58  +
                /* ProtocolParserGenerator.kt:146 */}
          59  +
            /* ProtocolParserGenerator.kt:145 */;
          60  +
            /* ProtocolParserGenerator.kt:170 */
   44     61   
            if tmp.message.is_none() {
   45     62   
                tmp.message = _error_message;
   46     63   
            }
          64  +
            /* ProtocolParserGenerator.kt:179 */
   47     65   
            tmp
          66  +
            /* ProtocolParserGenerator.kt:139 */
   48     67   
        }),
          68  +
        /* ProtocolParserGenerator.kt:139 */
   49     69   
        "LimitExceededException" => crate::operation::describe_export::DescribeExportError::LimitExceededError({
          70  +
            /* RustType.kt:516 */
   50     71   
            #[allow(unused_mut)]
   51         -
            let mut tmp = {
   52         -
                #[allow(unused_mut)]
   53         -
                let mut output = crate::types::error::builders::LimitExceededErrorBuilder::default();
   54         -
                output = crate::protocol_serde::shape_limit_exceeded_exception::de_limit_exceeded_exception_json_err(_response_body, output)
   55         -
                    .map_err(crate::operation::describe_export::DescribeExportError::unhandled)?;
   56         -
                let output = output.meta(generic);
   57         -
                output.build()
   58         -
            };
          72  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          73  +
                /* ProtocolParserGenerator.kt:146 */ {
          74  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          75  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::LimitExceededErrorBuilder::default();
          76  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_limit_exceeded_exception::de_limit_exceeded_exception_json_err(_response_body, output).map_err(crate::operation::describe_export::DescribeExportError::unhandled)?;
          77  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          78  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
          79  +
                /* ProtocolParserGenerator.kt:146 */}
          80  +
            /* ProtocolParserGenerator.kt:145 */;
          81  +
            /* ProtocolParserGenerator.kt:170 */
   59     82   
            if tmp.message.is_none() {
   60     83   
                tmp.message = _error_message;
   61     84   
            }
          85  +
            /* ProtocolParserGenerator.kt:179 */
   62     86   
            tmp
          87  +
            /* ProtocolParserGenerator.kt:139 */
   63     88   
        }),
   64         -
        _ => crate::operation::describe_export::DescribeExportError::generic(generic),
          89  +
        /* ProtocolParserGenerator.kt:182 */
          90  +
        _ => crate::operation::describe_export::DescribeExportError::generic(generic), /* ProtocolParserGenerator.kt:133 */
   65     91   
    })
          92  +
    /* ProtocolParserGenerator.kt:99 */
   66     93   
}
   67     94   
          95  +
/* RustType.kt:516 */
   68     96   
#[allow(clippy::unnecessary_wraps)]
          97  +
/* ProtocolParserGenerator.kt:71 */
   69     98   
pub fn de_describe_export_http_response(
   70     99   
    _response_status: u16,
   71    100   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
   72    101   
    _response_body: &[u8],
   73    102   
) -> std::result::Result<crate::operation::describe_export::DescribeExportOutput, crate::operation::describe_export::DescribeExportError> {
         103  +
    /* ProtocolParserGenerator.kt:77 */
   74    104   
    Ok({
         105  +
        /* RustType.kt:516 */
   75    106   
        #[allow(unused_mut)]
         107  +
        /* ProtocolParserGenerator.kt:240 */
   76    108   
        let mut output = crate::operation::describe_export::builders::DescribeExportOutputBuilder::default();
         109  +
        /* ProtocolParserGenerator.kt:247 */
   77    110   
        output = crate::protocol_serde::shape_describe_export::de_describe_export(_response_body, output)
   78    111   
            .map_err(crate::operation::describe_export::DescribeExportError::unhandled)?;
         112  +
        /* ClientBuilderInstantiator.kt:56 */
   79    113   
        output.build()
         114  +
        /* ProtocolParserGenerator.kt:77 */
   80    115   
    })
         116  +
    /* ProtocolParserGenerator.kt:71 */
   81    117   
}
   82    118   
         119  +
/* JsonSerializerGenerator.kt:287 */
   83    120   
pub fn ser_describe_export_input(
   84    121   
    input: &crate::operation::describe_export::DescribeExportInput,
   85    122   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
         123  +
    /* JsonSerializerGenerator.kt:291 */
   86    124   
    let mut out = String::new();
         125  +
    /* JsonSerializerGenerator.kt:292 */
   87    126   
    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
         127  +
    /* JsonSerializerGenerator.kt:375 */
   88    128   
    crate::protocol_serde::shape_describe_export_input::ser_describe_export_input_input(&mut object, input)?;
         129  +
    /* JsonSerializerGenerator.kt:295 */
   89    130   
    object.finish();
         131  +
    /* JsonSerializerGenerator.kt:296 */
   90    132   
    Ok(::aws_smithy_types::body::SdkBody::from(out))
         133  +
    /* JsonSerializerGenerator.kt:287 */
   91    134   
}
   92    135   
         136  +
/* JsonParserGenerator.kt:148 */
   93    137   
pub(crate) fn de_describe_export(
   94    138   
    value: &[u8],
   95    139   
    mut builder: crate::operation::describe_export::builders::DescribeExportOutputBuilder,
   96    140   
) -> ::std::result::Result<
   97    141   
    crate::operation::describe_export::builders::DescribeExportOutputBuilder,
   98    142   
    ::aws_smithy_json::deserialize::error::DeserializeError,
   99    143   
> {
         144  +
    /* JsonParserGenerator.kt:153 */
  100    145   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
  101    146   
    let tokens = &mut tokens_owned;
  102    147   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
         148  +
    /* JsonParserGenerator.kt:684 */
  103    149   
    loop {
         150  +
        /* JsonParserGenerator.kt:685 */
  104    151   
        match tokens.next().transpose()? {
  105         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
  106         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
         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   
                    "ExportDescription" => {
  108         -
                    builder = builder.set_export_description(crate::protocol_serde::shape_export_description::de_export_description(tokens)?);
         158  +
                        /* JsonParserGenerator.kt:265 */
         159  +
                        builder = builder.set_export_description(
         160  +
                            /* JsonParserGenerator.kt:544 */
         161  +
                            crate::protocol_serde::shape_export_description::de_export_description(tokens)?, /* JsonParserGenerator.kt:265 */
         162  +
                        );
         163  +
                        /* JsonParserGenerator.kt:262 */
  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_export_input.rs

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

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

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

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

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

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

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

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

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

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

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