Client Test

Client Test

rev. dfb5149b65b7bcc09edd15b8e071ad43b5ac5943 (ignoring whitespace)

Files changed:

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

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

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

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

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

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

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

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

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

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

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

@@ -1,1 +19,34 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_untag_resource_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::untag_resource::UntagResourceInput,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.resource_arn {
           9  +
        /* JsonSerializerGenerator.kt:423 */
    7     10   
        object.key("ResourceArn").string(var_1.as_str());
          11  +
        /* JsonSerializerGenerator.kt:382 */
    8     12   
    }
          13  +
    /* JsonSerializerGenerator.kt:382 */
    9     14   
    if let Some(var_2) = &input.tag_keys {
          15  +
        /* JsonSerializerGenerator.kt:484 */
   10     16   
        let mut array_3 = object.key("TagKeys").start_array();
          17  +
        /* JsonSerializerGenerator.kt:524 */
   11     18   
        for item_4 in var_2 {
          19  +
            /* SerializerUtil.kt:42 */
   12     20   
            {
          21  +
                /* JsonSerializerGenerator.kt:423 */
   13     22   
                array_3.value().string(item_4.as_str());
          23  +
                /* SerializerUtil.kt:42 */
   14     24   
            }
          25  +
            /* JsonSerializerGenerator.kt:524 */
   15     26   
        }
          27  +
        /* JsonSerializerGenerator.kt:486 */
   16     28   
        array_3.finish();
          29  +
        /* JsonSerializerGenerator.kt:382 */
   17     30   
    }
          31  +
    /* JsonSerializerGenerator.kt:372 */
   18     32   
    Ok(())
          33  +
    /* JsonSerializerGenerator.kt:358 */
   19     34   
}

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

@@ -1,1 +55,106 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_update(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::types::Update,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* SerializerUtil.kt:42 */
    6      8   
    {
           9  +
        /* JsonSerializerGenerator.kt:495 */
    7     10   
        #[allow(unused_mut)]
          11  +
        /* JsonSerializerGenerator.kt:496 */
    8     12   
        let mut object_1 = object.key("Key").start_object();
          13  +
        /* JsonSerializerGenerator.kt:537 */
    9     14   
        for (key_2, value_3) in &input.key {
          15  +
            /* SerializerUtil.kt:42 */
   10     16   
            {
          17  +
                /* JsonSerializerGenerator.kt:495 */
   11     18   
                #[allow(unused_mut)]
          19  +
                /* JsonSerializerGenerator.kt:496 */
   12     20   
                let mut object_4 = object_1.key(key_2.as_str()).start_object();
          21  +
                /* JsonSerializerGenerator.kt:579 */
   13     22   
                crate::protocol_serde::shape_attribute_value::ser_attribute_value(&mut object_4, value_3)?;
          23  +
                /* JsonSerializerGenerator.kt:515 */
   14     24   
                object_4.finish();
          25  +
                /* SerializerUtil.kt:42 */
   15     26   
            }
          27  +
            /* JsonSerializerGenerator.kt:537 */
   16     28   
        }
          29  +
        /* JsonSerializerGenerator.kt:515 */
   17     30   
        object_1.finish();
          31  +
        /* SerializerUtil.kt:42 */
   18     32   
    }
          33  +
    /* SerializerUtil.kt:42 */
   19     34   
    {
          35  +
        /* JsonSerializerGenerator.kt:423 */
   20     36   
        object.key("UpdateExpression").string(input.update_expression.as_str());
          37  +
        /* SerializerUtil.kt:42 */
   21     38   
    }
          39  +
    /* SerializerUtil.kt:42 */
   22     40   
    {
          41  +
        /* JsonSerializerGenerator.kt:423 */
   23     42   
        object.key("TableName").string(input.table_name.as_str());
          43  +
        /* SerializerUtil.kt:42 */
   24     44   
    }
          45  +
    /* JsonSerializerGenerator.kt:382 */
   25     46   
    if let Some(var_5) = &input.condition_expression {
          47  +
        /* JsonSerializerGenerator.kt:423 */
   26     48   
        object.key("ConditionExpression").string(var_5.as_str());
          49  +
        /* JsonSerializerGenerator.kt:382 */
   27     50   
    }
          51  +
    /* JsonSerializerGenerator.kt:382 */
   28     52   
    if let Some(var_6) = &input.expression_attribute_names {
          53  +
        /* JsonSerializerGenerator.kt:495 */
   29     54   
        #[allow(unused_mut)]
          55  +
        /* JsonSerializerGenerator.kt:496 */
   30     56   
        let mut object_7 = object.key("ExpressionAttributeNames").start_object();
          57  +
        /* JsonSerializerGenerator.kt:537 */
   31     58   
        for (key_8, value_9) in var_6 {
          59  +
            /* SerializerUtil.kt:42 */
   32     60   
            {
          61  +
                /* JsonSerializerGenerator.kt:423 */
   33     62   
                object_7.key(key_8.as_str()).string(value_9.as_str());
          63  +
                /* SerializerUtil.kt:42 */
   34     64   
            }
          65  +
            /* JsonSerializerGenerator.kt:537 */
   35     66   
        }
          67  +
        /* JsonSerializerGenerator.kt:515 */
   36     68   
        object_7.finish();
          69  +
        /* JsonSerializerGenerator.kt:382 */
   37     70   
    }
          71  +
    /* JsonSerializerGenerator.kt:382 */
   38     72   
    if let Some(var_10) = &input.expression_attribute_values {
          73  +
        /* JsonSerializerGenerator.kt:495 */
   39     74   
        #[allow(unused_mut)]
          75  +
        /* JsonSerializerGenerator.kt:496 */
   40     76   
        let mut object_11 = object.key("ExpressionAttributeValues").start_object();
          77  +
        /* JsonSerializerGenerator.kt:537 */
   41     78   
        for (key_12, value_13) in var_10 {
          79  +
            /* SerializerUtil.kt:42 */
   42     80   
            {
          81  +
                /* JsonSerializerGenerator.kt:495 */
   43     82   
                #[allow(unused_mut)]
          83  +
                /* JsonSerializerGenerator.kt:496 */
   44     84   
                let mut object_14 = object_11.key(key_12.as_str()).start_object();
          85  +
                /* JsonSerializerGenerator.kt:579 */
   45     86   
                crate::protocol_serde::shape_attribute_value::ser_attribute_value(&mut object_14, value_13)?;
          87  +
                /* JsonSerializerGenerator.kt:515 */
   46     88   
                object_14.finish();
          89  +
                /* SerializerUtil.kt:42 */
   47     90   
            }
          91  +
            /* JsonSerializerGenerator.kt:537 */
   48     92   
        }
          93  +
        /* JsonSerializerGenerator.kt:515 */
   49     94   
        object_11.finish();
          95  +
        /* JsonSerializerGenerator.kt:382 */
   50     96   
    }
          97  +
    /* JsonSerializerGenerator.kt:382 */
   51     98   
    if let Some(var_15) = &input.return_values_on_condition_check_failure {
          99  +
        /* JsonSerializerGenerator.kt:423 */
   52    100   
        object.key("ReturnValuesOnConditionCheckFailure").string(var_15.as_str());
         101  +
        /* JsonSerializerGenerator.kt:382 */
   53    102   
    }
         103  +
    /* JsonSerializerGenerator.kt:372 */
   54    104   
    Ok(())
         105  +
    /* JsonSerializerGenerator.kt:358 */
   55    106   
}

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

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

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

@@ -1,1 +16,28 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_update_continuous_backups_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::update_continuous_backups::UpdateContinuousBackupsInput,
    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.point_in_time_recovery_specification {
          15  +
        /* JsonSerializerGenerator.kt:495 */
   10     16   
        #[allow(unused_mut)]
          17  +
        /* JsonSerializerGenerator.kt:496 */
   11     18   
        let mut object_3 = object.key("PointInTimeRecoverySpecification").start_object();
          19  +
        /* JsonSerializerGenerator.kt:375 */
   12     20   
        crate::protocol_serde::shape_point_in_time_recovery_specification::ser_point_in_time_recovery_specification(&mut object_3, var_2)?;
          21  +
        /* JsonSerializerGenerator.kt:515 */
   13     22   
        object_3.finish();
          23  +
        /* JsonSerializerGenerator.kt:382 */
   14     24   
    }
          25  +
    /* JsonSerializerGenerator.kt:372 */
   15     26   
    Ok(())
          27  +
    /* JsonSerializerGenerator.kt:358 */
   16     28   
}

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

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

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

@@ -1,1 +16,28 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_update_contributor_insights_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::update_contributor_insights::UpdateContributorInsightsInput,
    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:382 */
   12     20   
    if let Some(var_3) = &input.contributor_insights_action {
          21  +
        /* JsonSerializerGenerator.kt:423 */
   13     22   
        object.key("ContributorInsightsAction").string(var_3.as_str());
          23  +
        /* JsonSerializerGenerator.kt:382 */
   14     24   
    }
          25  +
    /* JsonSerializerGenerator.kt:372 */
   15     26   
    Ok(())
          27  +
    /* JsonSerializerGenerator.kt:358 */
   16     28   
}

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

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

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

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

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

@@ -1,1 +22,40 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_update_global_table_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::update_global_table::UpdateGlobalTableInput,
    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:382 */
    9     14   
    if let Some(var_2) = &input.replica_updates {
          15  +
        /* JsonSerializerGenerator.kt:484 */
   10     16   
        let mut array_3 = object.key("ReplicaUpdates").start_array();
          17  +
        /* JsonSerializerGenerator.kt:524 */
   11     18   
        for item_4 in var_2 {
          19  +
            /* SerializerUtil.kt:42 */
   12     20   
            {
          21  +
                /* JsonSerializerGenerator.kt:495 */
   13     22   
                #[allow(unused_mut)]
          23  +
                /* JsonSerializerGenerator.kt:496 */
   14     24   
                let mut object_5 = array_3.value().start_object();
          25  +
                /* JsonSerializerGenerator.kt:375 */
   15     26   
                crate::protocol_serde::shape_replica_update::ser_replica_update(&mut object_5, item_4)?;
          27  +
                /* JsonSerializerGenerator.kt:515 */
   16     28   
                object_5.finish();
          29  +
                /* SerializerUtil.kt:42 */
   17     30   
            }
          31  +
            /* JsonSerializerGenerator.kt:524 */
   18     32   
        }
          33  +
        /* JsonSerializerGenerator.kt:486 */
   19     34   
        array_3.finish();
          35  +
        /* JsonSerializerGenerator.kt:382 */
   20     36   
    }
          37  +
    /* JsonSerializerGenerator.kt:372 */
   21     38   
    Ok(())
          39  +
    /* JsonSerializerGenerator.kt:358 */
   22     40   
}

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

@@ -1,1 +208,298 @@
    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_update_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::update_global_table_settings::UpdateGlobalTableSettingsOutput,
    9     11   
    crate::operation::update_global_table_settings::UpdateGlobalTableSettingsError,
   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::update_global_table_settings::UpdateGlobalTableSettingsError::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::update_global_table_settings::UpdateGlobalTableSettingsError::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   
        "GlobalTableNotFoundException" => crate::operation::update_global_table_settings::UpdateGlobalTableSettingsError::GlobalTableNotFoundError({
          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::GlobalTableNotFoundErrorBuilder::default();
   31         -
                output = crate::protocol_serde::shape_global_table_not_found_exception::de_global_table_not_found_exception_json_err(
   32         -
                    _response_body,
   33         -
                    output,
   34         -
                )
   35         -
                .map_err(crate::operation::update_global_table_settings::UpdateGlobalTableSettingsError::unhandled)?;
   36         -
                let output = output.meta(generic);
   37         -
                output.build()
   38         -
            };
          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::GlobalTableNotFoundErrorBuilder::default();
          41  +
                    /* 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::update_global_table_settings::UpdateGlobalTableSettingsError::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 */
   39     47   
            if tmp.message.is_none() {
   40     48   
                tmp.message = _error_message;
   41     49   
            }
          50  +
            /* ProtocolParserGenerator.kt:179 */
   42     51   
            tmp
          52  +
            /* ProtocolParserGenerator.kt:139 */
   43     53   
        }),
          54  +
        /* ProtocolParserGenerator.kt:139 */
   44     55   
        "IndexNotFoundException" => crate::operation::update_global_table_settings::UpdateGlobalTableSettingsError::IndexNotFoundError({
          56  +
            /* RustType.kt:516 */
   45     57   
            #[allow(unused_mut)]
   46         -
            let mut tmp = {
   47         -
                #[allow(unused_mut)]
   48         -
                let mut output = crate::types::error::builders::IndexNotFoundErrorBuilder::default();
   49         -
                output = crate::protocol_serde::shape_index_not_found_exception::de_index_not_found_exception_json_err(_response_body, output)
   50         -
                    .map_err(crate::operation::update_global_table_settings::UpdateGlobalTableSettingsError::unhandled)?;
   51         -
                let output = output.meta(generic);
   52         -
                output.build()
   53         -
            };
          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::IndexNotFoundErrorBuilder::default();
          62  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_index_not_found_exception::de_index_not_found_exception_json_err(_response_body, output).map_err(crate::operation::update_global_table_settings::UpdateGlobalTableSettingsError::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 */
   54     68   
            if tmp.message.is_none() {
   55     69   
                tmp.message = _error_message;
   56     70   
            }
          71  +
            /* ProtocolParserGenerator.kt:179 */
   57     72   
            tmp
          73  +
            /* ProtocolParserGenerator.kt:139 */
   58     74   
        }),
          75  +
        /* ProtocolParserGenerator.kt:139 */
   59     76   
        "InternalServerError" => crate::operation::update_global_table_settings::UpdateGlobalTableSettingsError::InternalServerError({
          77  +
            /* RustType.kt:516 */
   60     78   
            #[allow(unused_mut)]
   61         -
            let mut tmp = {
   62         -
                #[allow(unused_mut)]
   63         -
                let mut output = crate::types::error::builders::InternalServerErrorBuilder::default();
   64         -
                output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output)
   65         -
                    .map_err(crate::operation::update_global_table_settings::UpdateGlobalTableSettingsError::unhandled)?;
   66         -
                let output = output.meta(generic);
   67         -
                output.build()
   68         -
            };
          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::InternalServerErrorBuilder::default();
          83  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output).map_err(crate::operation::update_global_table_settings::UpdateGlobalTableSettingsError::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 */
   69     89   
            if tmp.message.is_none() {
   70     90   
                tmp.message = _error_message;
   71     91   
            }
          92  +
            /* ProtocolParserGenerator.kt:179 */
   72     93   
            tmp
          94  +
            /* ProtocolParserGenerator.kt:139 */
   73     95   
        }),
          96  +
        /* ProtocolParserGenerator.kt:139 */
   74     97   
        "InvalidEndpointException" => crate::operation::update_global_table_settings::UpdateGlobalTableSettingsError::InvalidEndpointError({
          98  +
            /* RustType.kt:516 */
   75     99   
            #[allow(unused_mut)]
   76         -
            let mut tmp = {
   77         -
                #[allow(unused_mut)]
   78         -
                let mut output = crate::types::error::builders::InvalidEndpointErrorBuilder::default();
   79         -
                output = crate::protocol_serde::shape_invalid_endpoint_exception::de_invalid_endpoint_exception_json_err(_response_body, output)
   80         -
                    .map_err(crate::operation::update_global_table_settings::UpdateGlobalTableSettingsError::unhandled)?;
   81         -
                let output = output.meta(generic);
   82         -
                output.build()
   83         -
            };
         100  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
         101  +
                /* ProtocolParserGenerator.kt:146 */ {
         102  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
         103  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::InvalidEndpointErrorBuilder::default();
         104  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_invalid_endpoint_exception::de_invalid_endpoint_exception_json_err(_response_body, output).map_err(crate::operation::update_global_table_settings::UpdateGlobalTableSettingsError::unhandled)?;
         105  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
         106  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
         107  +
                /* ProtocolParserGenerator.kt:146 */}
         108  +
            /* ProtocolParserGenerator.kt:145 */;
         109  +
            /* ProtocolParserGenerator.kt:170 */
   84    110   
            if tmp.message.is_none() {
   85    111   
                tmp.message = _error_message;
   86    112   
            }
         113  +
            /* ProtocolParserGenerator.kt:179 */
   87    114   
            tmp
         115  +
            /* ProtocolParserGenerator.kt:139 */
   88    116   
        }),
         117  +
        /* ProtocolParserGenerator.kt:139 */
   89    118   
        "LimitExceededException" => crate::operation::update_global_table_settings::UpdateGlobalTableSettingsError::LimitExceededError({
         119  +
            /* RustType.kt:516 */
   90    120   
            #[allow(unused_mut)]
   91         -
            let mut tmp = {
   92         -
                #[allow(unused_mut)]
   93         -
                let mut output = crate::types::error::builders::LimitExceededErrorBuilder::default();
   94         -
                output = crate::protocol_serde::shape_limit_exceeded_exception::de_limit_exceeded_exception_json_err(_response_body, output)
   95         -
                    .map_err(crate::operation::update_global_table_settings::UpdateGlobalTableSettingsError::unhandled)?;
   96         -
                let output = output.meta(generic);
   97         -
                output.build()
   98         -
            };
         121  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
         122  +
                /* ProtocolParserGenerator.kt:146 */ {
         123  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
         124  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::LimitExceededErrorBuilder::default();
         125  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_limit_exceeded_exception::de_limit_exceeded_exception_json_err(_response_body, output).map_err(crate::operation::update_global_table_settings::UpdateGlobalTableSettingsError::unhandled)?;
         126  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
         127  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
         128  +
                /* ProtocolParserGenerator.kt:146 */}
         129  +
            /* ProtocolParserGenerator.kt:145 */;
         130  +
            /* ProtocolParserGenerator.kt:170 */
   99    131   
            if tmp.message.is_none() {
  100    132   
                tmp.message = _error_message;
  101    133   
            }
         134  +
            /* ProtocolParserGenerator.kt:179 */
  102    135   
            tmp
         136  +
            /* ProtocolParserGenerator.kt:139 */
  103    137   
        }),
         138  +
        /* ProtocolParserGenerator.kt:139 */
  104    139   
        "ReplicaNotFoundException" => crate::operation::update_global_table_settings::UpdateGlobalTableSettingsError::ReplicaNotFoundError({
         140  +
            /* RustType.kt:516 */
  105    141   
            #[allow(unused_mut)]
  106         -
            let mut tmp = {
  107         -
                #[allow(unused_mut)]
  108         -
                let mut output = crate::types::error::builders::ReplicaNotFoundErrorBuilder::default();
  109         -
                output = crate::protocol_serde::shape_replica_not_found_exception::de_replica_not_found_exception_json_err(_response_body, output)
  110         -
                    .map_err(crate::operation::update_global_table_settings::UpdateGlobalTableSettingsError::unhandled)?;
  111         -
                let output = output.meta(generic);
  112         -
                output.build()
  113         -
            };
         142  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
         143  +
                /* ProtocolParserGenerator.kt:146 */ {
         144  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
         145  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::ReplicaNotFoundErrorBuilder::default();
         146  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_replica_not_found_exception::de_replica_not_found_exception_json_err(_response_body, output).map_err(crate::operation::update_global_table_settings::UpdateGlobalTableSettingsError::unhandled)?;
         147  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
         148  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
         149  +
                /* ProtocolParserGenerator.kt:146 */}
         150  +
            /* ProtocolParserGenerator.kt:145 */;
         151  +
            /* ProtocolParserGenerator.kt:170 */
  114    152   
            if tmp.message.is_none() {
  115    153   
                tmp.message = _error_message;
  116    154   
            }
         155  +
            /* ProtocolParserGenerator.kt:179 */
  117    156   
            tmp
         157  +
            /* ProtocolParserGenerator.kt:139 */
  118    158   
        }),
         159  +
        /* ProtocolParserGenerator.kt:139 */
  119    160   
        "ResourceInUseException" => crate::operation::update_global_table_settings::UpdateGlobalTableSettingsError::ResourceInUseError({
         161  +
            /* RustType.kt:516 */
  120    162   
            #[allow(unused_mut)]
  121         -
            let mut tmp = {
  122         -
                #[allow(unused_mut)]
  123         -
                let mut output = crate::types::error::builders::ResourceInUseErrorBuilder::default();
  124         -
                output = crate::protocol_serde::shape_resource_in_use_exception::de_resource_in_use_exception_json_err(_response_body, output)
  125         -
                    .map_err(crate::operation::update_global_table_settings::UpdateGlobalTableSettingsError::unhandled)?;
  126         -
                let output = output.meta(generic);
  127         -
                output.build()
  128         -
            };
         163  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
         164  +
                /* ProtocolParserGenerator.kt:146 */ {
         165  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
         166  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::ResourceInUseErrorBuilder::default();
         167  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_resource_in_use_exception::de_resource_in_use_exception_json_err(_response_body, output).map_err(crate::operation::update_global_table_settings::UpdateGlobalTableSettingsError::unhandled)?;
         168  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
         169  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
         170  +
                /* ProtocolParserGenerator.kt:146 */}
         171  +
            /* ProtocolParserGenerator.kt:145 */;
         172  +
            /* ProtocolParserGenerator.kt:170 */
  129    173   
            if tmp.message.is_none() {
  130    174   
                tmp.message = _error_message;
  131    175   
            }
         176  +
            /* ProtocolParserGenerator.kt:179 */
  132    177   
            tmp
         178  +
            /* ProtocolParserGenerator.kt:139 */
  133    179   
        }),
  134         -
        _ => crate::operation::update_global_table_settings::UpdateGlobalTableSettingsError::generic(generic),
         180  +
        /* ProtocolParserGenerator.kt:182 */
         181  +
        _ => crate::operation::update_global_table_settings::UpdateGlobalTableSettingsError::generic(generic), /* ProtocolParserGenerator.kt:133 */
  135    182   
    })
         183  +
    /* ProtocolParserGenerator.kt:99 */
  136    184   
}
  137    185   
         186  +
/* RustType.kt:516 */
  138    187   
#[allow(clippy::unnecessary_wraps)]
         188  +
/* ProtocolParserGenerator.kt:71 */
  139    189   
pub fn de_update_global_table_settings_http_response(
  140    190   
    _response_status: u16,
  141    191   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
  142    192   
    _response_body: &[u8],
  143    193   
) -> std::result::Result<
  144    194   
    crate::operation::update_global_table_settings::UpdateGlobalTableSettingsOutput,
  145    195   
    crate::operation::update_global_table_settings::UpdateGlobalTableSettingsError,
  146    196   
> {
         197  +
    /* ProtocolParserGenerator.kt:77 */
  147    198   
    Ok({
         199  +
        /* RustType.kt:516 */
  148    200   
        #[allow(unused_mut)]
         201  +
        /* ProtocolParserGenerator.kt:240 */
  149    202   
        let mut output = crate::operation::update_global_table_settings::builders::UpdateGlobalTableSettingsOutputBuilder::default();
         203  +
        /* ProtocolParserGenerator.kt:247 */
  150    204   
        output = crate::protocol_serde::shape_update_global_table_settings::de_update_global_table_settings(_response_body, output)
  151    205   
            .map_err(crate::operation::update_global_table_settings::UpdateGlobalTableSettingsError::unhandled)?;
         206  +
        /* ClientBuilderInstantiator.kt:56 */
  152    207   
        output.build()
         208  +
        /* ProtocolParserGenerator.kt:77 */
  153    209   
    })
         210  +
    /* ProtocolParserGenerator.kt:71 */
  154    211   
}
  155    212   
         213  +
/* JsonSerializerGenerator.kt:287 */
  156    214   
pub fn ser_update_global_table_settings_input(
  157    215   
    input: &crate::operation::update_global_table_settings::UpdateGlobalTableSettingsInput,
  158    216   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
         217  +
    /* JsonSerializerGenerator.kt:291 */
  159    218   
    let mut out = String::new();
         219  +
    /* JsonSerializerGenerator.kt:292 */
  160    220   
    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
         221  +
    /* JsonSerializerGenerator.kt:375 */
  161    222   
    crate::protocol_serde::shape_update_global_table_settings_input::ser_update_global_table_settings_input_input(&mut object, input)?;
         223  +
    /* JsonSerializerGenerator.kt:295 */
  162    224   
    object.finish();
         225  +
    /* JsonSerializerGenerator.kt:296 */
  163    226   
    Ok(::aws_smithy_types::body::SdkBody::from(out))
         227  +
    /* JsonSerializerGenerator.kt:287 */
  164    228   
}
  165    229   
         230  +
/* JsonParserGenerator.kt:148 */
  166    231   
pub(crate) fn de_update_global_table_settings(
  167    232   
    value: &[u8],
  168    233   
    mut builder: crate::operation::update_global_table_settings::builders::UpdateGlobalTableSettingsOutputBuilder,
  169    234   
) -> ::std::result::Result<
  170    235   
    crate::operation::update_global_table_settings::builders::UpdateGlobalTableSettingsOutputBuilder,
  171    236   
    ::aws_smithy_json::deserialize::error::DeserializeError,
  172    237   
> {
         238  +
    /* JsonParserGenerator.kt:153 */
  173    239   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
  174    240   
    let tokens = &mut tokens_owned;
  175    241   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
         242  +
    /* JsonParserGenerator.kt:684 */
  176    243   
    loop {
         244  +
        /* JsonParserGenerator.kt:685 */
  177    245   
        match tokens.next().transpose()? {
  178         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
  179         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
         246  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
         247  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
         248  +
                /* JsonParserGenerator.kt:260 */
         249  +
                match key.to_unescaped()?.as_ref() {
         250  +
                    /* JsonParserGenerator.kt:262 */
  180    251   
                    "GlobalTableName" => {
         252  +
                        /* JsonParserGenerator.kt:265 */
  181    253   
                        builder = builder.set_global_table_name(
         254  +
                            /* JsonParserGenerator.kt:354 */
  182    255   
                            ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
  183         -
                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
  184         -
                            .transpose()?,
         256  +
                                .map(|s|
         257  +
                                /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
         258  +
                                    /* JsonParserGenerator.kt:348 */u.into_owned()
         259  +
                                /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
         260  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
  185    261   
                        );
         262  +
                        /* JsonParserGenerator.kt:262 */
  186    263   
                    }
         264  +
                    /* JsonParserGenerator.kt:262 */
  187    265   
                    "ReplicaSettings" => {
         266  +
                        /* JsonParserGenerator.kt:265 */
  188    267   
                        builder = builder.set_replica_settings(
  189         -
                        crate::protocol_serde::shape_replica_settings_description_list::de_replica_settings_description_list(tokens)?,
  190         -
                    );
         268  +
                            /* JsonParserGenerator.kt:451 */crate::protocol_serde::shape_replica_settings_description_list::de_replica_settings_description_list(tokens)?
         269  +
                        /* JsonParserGenerator.kt:265 */);
         270  +
                        /* JsonParserGenerator.kt:262 */
         271  +
                    }
         272  +
                    /* JsonParserGenerator.kt:290 */
         273  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
  191    274   
                }
  192         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
  193         -
            },
         275  +
                /* JsonParserGenerator.kt:686 */
         276  +
            }
         277  +
            /* JsonParserGenerator.kt:695 */
  194    278   
            other => {
  195    279   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
  196    280   
                    "expected object key or end object, found: {:?}",
  197    281   
                    other
  198    282   
                )))
         283  +
            } /* JsonParserGenerator.kt:685 */
  199    284   
        }
         285  +
        /* JsonParserGenerator.kt:684 */
  200    286   
    }
  201         -
    }
         287  +
    /* JsonParserGenerator.kt:250 */
  202    288   
    if tokens.next().is_some() {
         289  +
        /* JsonParserGenerator.kt:251 */
  203    290   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
  204    291   
            "found more JSON tokens after completing parsing",
  205    292   
        ));
         293  +
        /* JsonParserGenerator.kt:250 */
  206    294   
    }
         295  +
    /* JsonParserGenerator.kt:163 */
  207    296   
    Ok(builder)
         297  +
    /* JsonParserGenerator.kt:148 */
  208    298   
}