Client Test

Client Test

rev. dfb5149b65b7bcc09edd15b8e071ad43b5ac5943 (ignoring whitespace)

Files changed:

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

@@ -1,1 +49,91 @@
    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_settings_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::update_global_table_settings::UpdateGlobalTableSettingsInput,
    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.global_table_billing_mode {
          15  +
        /* JsonSerializerGenerator.kt:423 */
   10     16   
        object.key("GlobalTableBillingMode").string(var_2.as_str());
          17  +
        /* JsonSerializerGenerator.kt:382 */
   11     18   
    }
          19  +
    /* JsonSerializerGenerator.kt:382 */
   12     20   
    if let Some(var_3) = &input.global_table_provisioned_write_capacity_units {
          21  +
        /* JsonSerializerGenerator.kt:432 */
   13     22   
        object.key("GlobalTableProvisionedWriteCapacityUnits").number(
   14     23   
            #[allow(clippy::useless_conversion)]
   15     24   
            ::aws_smithy_types::Number::NegInt((*var_3).into()),
   16     25   
        );
          26  +
        /* JsonSerializerGenerator.kt:382 */
   17     27   
    }
          28  +
    /* JsonSerializerGenerator.kt:382 */
   18     29   
    if let Some(var_4) = &input.global_table_provisioned_write_capacity_auto_scaling_settings_update {
          30  +
        /* JsonSerializerGenerator.kt:495 */
   19     31   
        #[allow(unused_mut)]
          32  +
        /* JsonSerializerGenerator.kt:496 */
   20     33   
        let mut object_5 = object.key("GlobalTableProvisionedWriteCapacityAutoScalingSettingsUpdate").start_object();
          34  +
        /* JsonSerializerGenerator.kt:375 */
   21     35   
        crate::protocol_serde::shape_auto_scaling_settings_update::ser_auto_scaling_settings_update(&mut object_5, var_4)?;
          36  +
        /* JsonSerializerGenerator.kt:515 */
   22     37   
        object_5.finish();
          38  +
        /* JsonSerializerGenerator.kt:382 */
   23     39   
    }
          40  +
    /* JsonSerializerGenerator.kt:382 */
   24     41   
    if let Some(var_6) = &input.global_table_global_secondary_index_settings_update {
          42  +
        /* JsonSerializerGenerator.kt:484 */
   25     43   
        let mut array_7 = object.key("GlobalTableGlobalSecondaryIndexSettingsUpdate").start_array();
          44  +
        /* JsonSerializerGenerator.kt:524 */
   26     45   
        for item_8 in var_6 {
          46  +
            /* SerializerUtil.kt:42 */
   27     47   
            {
          48  +
                /* JsonSerializerGenerator.kt:495 */
   28     49   
                #[allow(unused_mut)]
          50  +
                /* JsonSerializerGenerator.kt:496 */
   29     51   
                let mut object_9 = array_7.value().start_object();
          52  +
                /* JsonSerializerGenerator.kt:375 */
   30     53   
                crate::protocol_serde::shape_global_table_global_secondary_index_settings_update::ser_global_table_global_secondary_index_settings_update(&mut object_9, item_8)?;
          54  +
                /* JsonSerializerGenerator.kt:515 */
   31     55   
                object_9.finish();
          56  +
                /* SerializerUtil.kt:42 */
   32     57   
            }
          58  +
            /* JsonSerializerGenerator.kt:524 */
   33     59   
        }
          60  +
        /* JsonSerializerGenerator.kt:486 */
   34     61   
        array_7.finish();
          62  +
        /* JsonSerializerGenerator.kt:382 */
   35     63   
    }
          64  +
    /* JsonSerializerGenerator.kt:382 */
   36     65   
    if let Some(var_10) = &input.replica_settings_update {
          66  +
        /* JsonSerializerGenerator.kt:484 */
   37     67   
        let mut array_11 = object.key("ReplicaSettingsUpdate").start_array();
          68  +
        /* JsonSerializerGenerator.kt:524 */
   38     69   
        for item_12 in var_10 {
          70  +
            /* SerializerUtil.kt:42 */
   39     71   
            {
          72  +
                /* JsonSerializerGenerator.kt:495 */
   40     73   
                #[allow(unused_mut)]
          74  +
                /* JsonSerializerGenerator.kt:496 */
   41     75   
                let mut object_13 = array_11.value().start_object();
          76  +
                /* JsonSerializerGenerator.kt:375 */
   42     77   
                crate::protocol_serde::shape_replica_settings_update::ser_replica_settings_update(&mut object_13, item_12)?;
          78  +
                /* JsonSerializerGenerator.kt:515 */
   43     79   
                object_13.finish();
          80  +
                /* SerializerUtil.kt:42 */
   44     81   
            }
          82  +
            /* JsonSerializerGenerator.kt:524 */
   45     83   
        }
          84  +
        /* JsonSerializerGenerator.kt:486 */
   46     85   
        array_11.finish();
          86  +
        /* JsonSerializerGenerator.kt:382 */
   47     87   
    }
          88  +
    /* JsonSerializerGenerator.kt:372 */
   48     89   
    Ok(())
          90  +
    /* JsonSerializerGenerator.kt:358 */
   49     91   
}

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

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

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

@@ -1,1 +90,176 @@
    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_item_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::update_item::UpdateItemInput,
    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.key {
          15  +
        /* JsonSerializerGenerator.kt:495 */
   10     16   
        #[allow(unused_mut)]
          17  +
        /* JsonSerializerGenerator.kt:496 */
   11     18   
        let mut object_3 = object.key("Key").start_object();
          19  +
        /* JsonSerializerGenerator.kt:537 */
   12     20   
        for (key_4, value_5) in var_2 {
          21  +
            /* SerializerUtil.kt:42 */
   13     22   
            {
          23  +
                /* JsonSerializerGenerator.kt:495 */
   14     24   
                #[allow(unused_mut)]
          25  +
                /* JsonSerializerGenerator.kt:496 */
   15     26   
                let mut object_6 = object_3.key(key_4.as_str()).start_object();
          27  +
                /* JsonSerializerGenerator.kt:579 */
   16     28   
                crate::protocol_serde::shape_attribute_value::ser_attribute_value(&mut object_6, value_5)?;
          29  +
                /* JsonSerializerGenerator.kt:515 */
   17     30   
                object_6.finish();
          31  +
                /* SerializerUtil.kt:42 */
   18     32   
            }
          33  +
            /* JsonSerializerGenerator.kt:537 */
   19     34   
        }
          35  +
        /* JsonSerializerGenerator.kt:515 */
   20     36   
        object_3.finish();
          37  +
        /* JsonSerializerGenerator.kt:382 */
   21     38   
    }
          39  +
    /* JsonSerializerGenerator.kt:382 */
   22     40   
    if let Some(var_7) = &input.attribute_updates {
          41  +
        /* JsonSerializerGenerator.kt:495 */
   23     42   
        #[allow(unused_mut)]
          43  +
        /* JsonSerializerGenerator.kt:496 */
   24     44   
        let mut object_8 = object.key("AttributeUpdates").start_object();
          45  +
        /* JsonSerializerGenerator.kt:537 */
   25     46   
        for (key_9, value_10) in var_7 {
          47  +
            /* SerializerUtil.kt:42 */
   26     48   
            {
          49  +
                /* JsonSerializerGenerator.kt:495 */
   27     50   
                #[allow(unused_mut)]
          51  +
                /* JsonSerializerGenerator.kt:496 */
   28     52   
                let mut object_11 = object_8.key(key_9.as_str()).start_object();
          53  +
                /* JsonSerializerGenerator.kt:375 */
   29     54   
                crate::protocol_serde::shape_attribute_value_update::ser_attribute_value_update(&mut object_11, value_10)?;
          55  +
                /* JsonSerializerGenerator.kt:515 */
   30     56   
                object_11.finish();
          57  +
                /* SerializerUtil.kt:42 */
   31     58   
            }
          59  +
            /* JsonSerializerGenerator.kt:537 */
   32     60   
        }
          61  +
        /* JsonSerializerGenerator.kt:515 */
   33     62   
        object_8.finish();
          63  +
        /* JsonSerializerGenerator.kt:382 */
   34     64   
    }
          65  +
    /* JsonSerializerGenerator.kt:382 */
   35     66   
    if let Some(var_12) = &input.expected {
          67  +
        /* JsonSerializerGenerator.kt:495 */
   36     68   
        #[allow(unused_mut)]
          69  +
        /* JsonSerializerGenerator.kt:496 */
   37     70   
        let mut object_13 = object.key("Expected").start_object();
          71  +
        /* JsonSerializerGenerator.kt:537 */
   38     72   
        for (key_14, value_15) in var_12 {
          73  +
            /* SerializerUtil.kt:42 */
   39     74   
            {
          75  +
                /* JsonSerializerGenerator.kt:495 */
   40     76   
                #[allow(unused_mut)]
          77  +
                /* JsonSerializerGenerator.kt:496 */
   41     78   
                let mut object_16 = object_13.key(key_14.as_str()).start_object();
          79  +
                /* JsonSerializerGenerator.kt:375 */
   42     80   
                crate::protocol_serde::shape_expected_attribute_value::ser_expected_attribute_value(&mut object_16, value_15)?;
          81  +
                /* JsonSerializerGenerator.kt:515 */
   43     82   
                object_16.finish();
          83  +
                /* SerializerUtil.kt:42 */
   44     84   
            }
          85  +
            /* JsonSerializerGenerator.kt:537 */
   45     86   
        }
          87  +
        /* JsonSerializerGenerator.kt:515 */
   46     88   
        object_13.finish();
          89  +
        /* JsonSerializerGenerator.kt:382 */
   47     90   
    }
          91  +
    /* JsonSerializerGenerator.kt:382 */
   48     92   
    if let Some(var_17) = &input.conditional_operator {
          93  +
        /* JsonSerializerGenerator.kt:423 */
   49     94   
        object.key("ConditionalOperator").string(var_17.as_str());
          95  +
        /* JsonSerializerGenerator.kt:382 */
   50     96   
    }
          97  +
    /* JsonSerializerGenerator.kt:382 */
   51     98   
    if let Some(var_18) = &input.return_values {
          99  +
        /* JsonSerializerGenerator.kt:423 */
   52    100   
        object.key("ReturnValues").string(var_18.as_str());
         101  +
        /* JsonSerializerGenerator.kt:382 */
   53    102   
    }
         103  +
    /* JsonSerializerGenerator.kt:382 */
   54    104   
    if let Some(var_19) = &input.return_consumed_capacity {
         105  +
        /* JsonSerializerGenerator.kt:423 */
   55    106   
        object.key("ReturnConsumedCapacity").string(var_19.as_str());
         107  +
        /* JsonSerializerGenerator.kt:382 */
   56    108   
    }
         109  +
    /* JsonSerializerGenerator.kt:382 */
   57    110   
    if let Some(var_20) = &input.return_item_collection_metrics {
         111  +
        /* JsonSerializerGenerator.kt:423 */
   58    112   
        object.key("ReturnItemCollectionMetrics").string(var_20.as_str());
         113  +
        /* JsonSerializerGenerator.kt:382 */
   59    114   
    }
         115  +
    /* JsonSerializerGenerator.kt:382 */
   60    116   
    if let Some(var_21) = &input.update_expression {
         117  +
        /* JsonSerializerGenerator.kt:423 */
   61    118   
        object.key("UpdateExpression").string(var_21.as_str());
         119  +
        /* JsonSerializerGenerator.kt:382 */
   62    120   
    }
         121  +
    /* JsonSerializerGenerator.kt:382 */
   63    122   
    if let Some(var_22) = &input.condition_expression {
         123  +
        /* JsonSerializerGenerator.kt:423 */
   64    124   
        object.key("ConditionExpression").string(var_22.as_str());
         125  +
        /* JsonSerializerGenerator.kt:382 */
   65    126   
    }
         127  +
    /* JsonSerializerGenerator.kt:382 */
   66    128   
    if let Some(var_23) = &input.expression_attribute_names {
         129  +
        /* JsonSerializerGenerator.kt:495 */
   67    130   
        #[allow(unused_mut)]
         131  +
        /* JsonSerializerGenerator.kt:496 */
   68    132   
        let mut object_24 = object.key("ExpressionAttributeNames").start_object();
         133  +
        /* JsonSerializerGenerator.kt:537 */
   69    134   
        for (key_25, value_26) in var_23 {
         135  +
            /* SerializerUtil.kt:42 */
   70    136   
            {
         137  +
                /* JsonSerializerGenerator.kt:423 */
   71    138   
                object_24.key(key_25.as_str()).string(value_26.as_str());
         139  +
                /* SerializerUtil.kt:42 */
   72    140   
            }
         141  +
            /* JsonSerializerGenerator.kt:537 */
   73    142   
        }
         143  +
        /* JsonSerializerGenerator.kt:515 */
   74    144   
        object_24.finish();
         145  +
        /* JsonSerializerGenerator.kt:382 */
   75    146   
    }
         147  +
    /* JsonSerializerGenerator.kt:382 */
   76    148   
    if let Some(var_27) = &input.expression_attribute_values {
         149  +
        /* JsonSerializerGenerator.kt:495 */
   77    150   
        #[allow(unused_mut)]
         151  +
        /* JsonSerializerGenerator.kt:496 */
   78    152   
        let mut object_28 = object.key("ExpressionAttributeValues").start_object();
         153  +
        /* JsonSerializerGenerator.kt:537 */
   79    154   
        for (key_29, value_30) in var_27 {
         155  +
            /* SerializerUtil.kt:42 */
   80    156   
            {
         157  +
                /* JsonSerializerGenerator.kt:495 */
   81    158   
                #[allow(unused_mut)]
         159  +
                /* JsonSerializerGenerator.kt:496 */
   82    160   
                let mut object_31 = object_28.key(key_29.as_str()).start_object();
         161  +
                /* JsonSerializerGenerator.kt:579 */
   83    162   
                crate::protocol_serde::shape_attribute_value::ser_attribute_value(&mut object_31, value_30)?;
         163  +
                /* JsonSerializerGenerator.kt:515 */
   84    164   
                object_31.finish();
         165  +
                /* SerializerUtil.kt:42 */
   85    166   
            }
         167  +
            /* JsonSerializerGenerator.kt:537 */
   86    168   
        }
         169  +
        /* JsonSerializerGenerator.kt:515 */
   87    170   
        object_28.finish();
         171  +
        /* JsonSerializerGenerator.kt:382 */
   88    172   
    }
         173  +
    /* JsonSerializerGenerator.kt:372 */
   89    174   
    Ok(())
         175  +
    /* JsonSerializerGenerator.kt:358 */
   90    176   
}

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

@@ -1,1 +31,58 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_update_replication_group_member_action(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::types::UpdateReplicationGroupMemberAction,
    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("RegionName").string(input.region_name.as_str());
          11  +
        /* SerializerUtil.kt:42 */
    8     12   
    }
          13  +
    /* JsonSerializerGenerator.kt:382 */
    9     14   
    if let Some(var_1) = &input.kms_master_key_id {
          15  +
        /* JsonSerializerGenerator.kt:423 */
   10     16   
        object.key("KMSMasterKeyId").string(var_1.as_str());
          17  +
        /* JsonSerializerGenerator.kt:382 */
   11     18   
    }
          19  +
    /* JsonSerializerGenerator.kt:382 */
   12     20   
    if let Some(var_2) = &input.provisioned_throughput_override {
          21  +
        /* JsonSerializerGenerator.kt:495 */
   13     22   
        #[allow(unused_mut)]
          23  +
        /* JsonSerializerGenerator.kt:496 */
   14     24   
        let mut object_3 = object.key("ProvisionedThroughputOverride").start_object();
          25  +
        /* JsonSerializerGenerator.kt:375 */
   15     26   
        crate::protocol_serde::shape_provisioned_throughput_override::ser_provisioned_throughput_override(&mut object_3, var_2)?;
          27  +
        /* JsonSerializerGenerator.kt:515 */
   16     28   
        object_3.finish();
          29  +
        /* JsonSerializerGenerator.kt:382 */
   17     30   
    }
          31  +
    /* JsonSerializerGenerator.kt:382 */
   18     32   
    if let Some(var_4) = &input.global_secondary_indexes {
          33  +
        /* JsonSerializerGenerator.kt:484 */
   19     34   
        let mut array_5 = object.key("GlobalSecondaryIndexes").start_array();
          35  +
        /* JsonSerializerGenerator.kt:524 */
   20     36   
        for item_6 in var_4 {
          37  +
            /* SerializerUtil.kt:42 */
   21     38   
            {
          39  +
                /* JsonSerializerGenerator.kt:495 */
   22     40   
                #[allow(unused_mut)]
          41  +
                /* JsonSerializerGenerator.kt:496 */
   23     42   
                let mut object_7 = array_5.value().start_object();
          43  +
                /* JsonSerializerGenerator.kt:375 */
   24     44   
                crate::protocol_serde::shape_replica_global_secondary_index::ser_replica_global_secondary_index(&mut object_7, item_6)?;
          45  +
                /* JsonSerializerGenerator.kt:515 */
   25     46   
                object_7.finish();
          47  +
                /* SerializerUtil.kt:42 */
   26     48   
            }
          49  +
            /* JsonSerializerGenerator.kt:524 */
   27     50   
        }
          51  +
        /* JsonSerializerGenerator.kt:486 */
   28     52   
        array_5.finish();
          53  +
        /* JsonSerializerGenerator.kt:382 */
   29     54   
    }
          55  +
    /* JsonSerializerGenerator.kt:372 */
   30     56   
    Ok(())
          57  +
    /* JsonSerializerGenerator.kt:358 */
   31     58   
}

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

@@ -1,1 +154,231 @@
    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_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_table::UpdateTableOutput, crate::operation::update_table::UpdateTableError> {
          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::update_table::UpdateTableError::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::update_table::UpdateTableError::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::update_table::UpdateTableError::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::update_table::UpdateTableError::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::update_table::UpdateTableError::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::update_table::UpdateTableError::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::update_table::UpdateTableError::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::update_table::UpdateTableError::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::update_table::UpdateTableError::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::update_table::UpdateTableError::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::update_table::UpdateTableError::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::update_table::UpdateTableError::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::update_table::UpdateTableError::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::update_table::UpdateTableError::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::update_table::UpdateTableError::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::update_table::UpdateTableError::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::update_table::UpdateTableError::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::update_table::UpdateTableError::generic(generic),
         131  +
        /* ProtocolParserGenerator.kt:182 */
         132  +
        _ => crate::operation::update_table::UpdateTableError::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_update_table_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::update_table::UpdateTableOutput, crate::operation::update_table::UpdateTableError> {
         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::update_table::builders::UpdateTableOutputBuilder::default();
         151  +
        /* ProtocolParserGenerator.kt:247 */
  107    152   
        output = crate::protocol_serde::shape_update_table::de_update_table(_response_body, output)
  108    153   
            .map_err(crate::operation::update_table::UpdateTableError::unhandled)?;
         154  +
        /* ClientBuilderInstantiator.kt:56 */
  109    155   
        output.build()
         156  +
        /* ProtocolParserGenerator.kt:77 */
  110    157   
    })
         158  +
    /* ProtocolParserGenerator.kt:71 */
  111    159   
}
  112    160   
         161  +
/* JsonSerializerGenerator.kt:287 */
  113    162   
pub fn ser_update_table_input(
  114    163   
    input: &crate::operation::update_table::UpdateTableInput,
  115    164   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
         165  +
    /* JsonSerializerGenerator.kt:291 */
  116    166   
    let mut out = String::new();
         167  +
    /* JsonSerializerGenerator.kt:292 */
  117    168   
    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
         169  +
    /* JsonSerializerGenerator.kt:375 */
  118    170   
    crate::protocol_serde::shape_update_table_input::ser_update_table_input_input(&mut object, input)?;
         171  +
    /* JsonSerializerGenerator.kt:295 */
  119    172   
    object.finish();
         173  +
    /* JsonSerializerGenerator.kt:296 */
  120    174   
    Ok(::aws_smithy_types::body::SdkBody::from(out))
         175  +
    /* JsonSerializerGenerator.kt:287 */
  121    176   
}
  122    177   
         178  +
/* JsonParserGenerator.kt:148 */
  123    179   
pub(crate) fn de_update_table(
  124    180   
    value: &[u8],
  125    181   
    mut builder: crate::operation::update_table::builders::UpdateTableOutputBuilder,
  126    182   
) -> ::std::result::Result<crate::operation::update_table::builders::UpdateTableOutputBuilder, ::aws_smithy_json::deserialize::error::DeserializeError>
  127    183   
{
         184  +
    /* JsonParserGenerator.kt:153 */
  128    185   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
  129    186   
    let tokens = &mut tokens_owned;
  130    187   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
         188  +
    /* JsonParserGenerator.kt:684 */
  131    189   
    loop {
         190  +
        /* JsonParserGenerator.kt:685 */
  132    191   
        match tokens.next().transpose()? {
  133         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
  134         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
         192  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
         193  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
         194  +
                /* JsonParserGenerator.kt:260 */
         195  +
                match key.to_unescaped()?.as_ref() {
         196  +
                    /* JsonParserGenerator.kt:262 */
  135    197   
                    "TableDescription" => {
  136         -
                    builder = builder.set_table_description(crate::protocol_serde::shape_table_description::de_table_description(tokens)?);
         198  +
                        /* JsonParserGenerator.kt:265 */
         199  +
                        builder = builder.set_table_description(
         200  +
                            /* JsonParserGenerator.kt:544 */
         201  +
                            crate::protocol_serde::shape_table_description::de_table_description(tokens)?, /* JsonParserGenerator.kt:265 */
         202  +
                        );
         203  +
                        /* JsonParserGenerator.kt:262 */
         204  +
                    }
         205  +
                    /* JsonParserGenerator.kt:290 */
         206  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
  137    207   
                }
  138         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
  139         -
            },
         208  +
                /* JsonParserGenerator.kt:686 */
         209  +
            }
         210  +
            /* JsonParserGenerator.kt:695 */
  140    211   
            other => {
  141    212   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
  142    213   
                    "expected object key or end object, found: {:?}",
  143    214   
                    other
  144    215   
                )))
         216  +
            } /* JsonParserGenerator.kt:685 */
  145    217   
        }
         218  +
        /* JsonParserGenerator.kt:684 */
  146    219   
    }
  147         -
    }
         220  +
    /* JsonParserGenerator.kt:250 */
  148    221   
    if tokens.next().is_some() {
         222  +
        /* JsonParserGenerator.kt:251 */
  149    223   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
  150    224   
            "found more JSON tokens after completing parsing",
  151    225   
        ));
         226  +
        /* JsonParserGenerator.kt:250 */
  152    227   
    }
         228  +
    /* JsonParserGenerator.kt:163 */
  153    229   
    Ok(builder)
         230  +
    /* JsonParserGenerator.kt:148 */
  154    231   
}

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

@@ -1,1 +67,130 @@
    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_table_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::update_table::UpdateTableInput,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.attribute_definitions {
           9  +
        /* JsonSerializerGenerator.kt:484 */
    7     10   
        let mut array_2 = object.key("AttributeDefinitions").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_attribute_definition::ser_attribute_definition(&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.table_name {
          33  +
        /* JsonSerializerGenerator.kt:423 */
   19     34   
        object.key("TableName").string(var_5.as_str());
          35  +
        /* JsonSerializerGenerator.kt:382 */
   20     36   
    }
          37  +
    /* JsonSerializerGenerator.kt:382 */
   21     38   
    if let Some(var_6) = &input.billing_mode {
          39  +
        /* JsonSerializerGenerator.kt:423 */
   22     40   
        object.key("BillingMode").string(var_6.as_str());
          41  +
        /* JsonSerializerGenerator.kt:382 */
   23     42   
    }
          43  +
    /* JsonSerializerGenerator.kt:382 */
   24     44   
    if let Some(var_7) = &input.provisioned_throughput {
          45  +
        /* JsonSerializerGenerator.kt:495 */
   25     46   
        #[allow(unused_mut)]
          47  +
        /* JsonSerializerGenerator.kt:496 */
   26     48   
        let mut object_8 = object.key("ProvisionedThroughput").start_object();
          49  +
        /* JsonSerializerGenerator.kt:375 */
   27     50   
        crate::protocol_serde::shape_provisioned_throughput::ser_provisioned_throughput(&mut object_8, var_7)?;
          51  +
        /* JsonSerializerGenerator.kt:515 */
   28     52   
        object_8.finish();
          53  +
        /* JsonSerializerGenerator.kt:382 */
   29     54   
    }
          55  +
    /* JsonSerializerGenerator.kt:382 */
   30     56   
    if let Some(var_9) = &input.global_secondary_index_updates {
          57  +
        /* JsonSerializerGenerator.kt:484 */
   31     58   
        let mut array_10 = object.key("GlobalSecondaryIndexUpdates").start_array();
          59  +
        /* JsonSerializerGenerator.kt:524 */
   32     60   
        for item_11 in var_9 {
          61  +
            /* SerializerUtil.kt:42 */
   33     62   
            {
          63  +
                /* JsonSerializerGenerator.kt:495 */
   34     64   
                #[allow(unused_mut)]
          65  +
                /* JsonSerializerGenerator.kt:496 */
   35     66   
                let mut object_12 = array_10.value().start_object();
          67  +
                /* JsonSerializerGenerator.kt:375 */
   36     68   
                crate::protocol_serde::shape_global_secondary_index_update::ser_global_secondary_index_update(&mut object_12, item_11)?;
          69  +
                /* JsonSerializerGenerator.kt:515 */
   37     70   
                object_12.finish();
          71  +
                /* SerializerUtil.kt:42 */
   38     72   
            }
          73  +
            /* JsonSerializerGenerator.kt:524 */
   39     74   
        }
          75  +
        /* JsonSerializerGenerator.kt:486 */
   40     76   
        array_10.finish();
          77  +
        /* JsonSerializerGenerator.kt:382 */
   41     78   
    }
          79  +
    /* JsonSerializerGenerator.kt:382 */
   42     80   
    if let Some(var_13) = &input.stream_specification {
          81  +
        /* JsonSerializerGenerator.kt:495 */
   43     82   
        #[allow(unused_mut)]
          83  +
        /* JsonSerializerGenerator.kt:496 */
   44     84   
        let mut object_14 = object.key("StreamSpecification").start_object();
          85  +
        /* JsonSerializerGenerator.kt:375 */
   45     86   
        crate::protocol_serde::shape_stream_specification::ser_stream_specification(&mut object_14, var_13)?;
          87  +
        /* JsonSerializerGenerator.kt:515 */
   46     88   
        object_14.finish();
          89  +
        /* JsonSerializerGenerator.kt:382 */
   47     90   
    }
          91  +
    /* JsonSerializerGenerator.kt:382 */
   48     92   
    if let Some(var_15) = &input.sse_specification {
          93  +
        /* JsonSerializerGenerator.kt:495 */
   49     94   
        #[allow(unused_mut)]
          95  +
        /* JsonSerializerGenerator.kt:496 */
   50     96   
        let mut object_16 = object.key("SSESpecification").start_object();
          97  +
        /* JsonSerializerGenerator.kt:375 */
   51     98   
        crate::protocol_serde::shape_sse_specification::ser_sse_specification(&mut object_16, var_15)?;
          99  +
        /* JsonSerializerGenerator.kt:515 */
   52    100   
        object_16.finish();
         101  +
        /* JsonSerializerGenerator.kt:382 */
   53    102   
    }
         103  +
    /* JsonSerializerGenerator.kt:382 */
   54    104   
    if let Some(var_17) = &input.replica_updates {
         105  +
        /* JsonSerializerGenerator.kt:484 */
   55    106   
        let mut array_18 = object.key("ReplicaUpdates").start_array();
         107  +
        /* JsonSerializerGenerator.kt:524 */
   56    108   
        for item_19 in var_17 {
         109  +
            /* SerializerUtil.kt:42 */
   57    110   
            {
         111  +
                /* JsonSerializerGenerator.kt:495 */
   58    112   
                #[allow(unused_mut)]
         113  +
                /* JsonSerializerGenerator.kt:496 */
   59    114   
                let mut object_20 = array_18.value().start_object();
         115  +
                /* JsonSerializerGenerator.kt:375 */
   60    116   
                crate::protocol_serde::shape_replication_group_update::ser_replication_group_update(&mut object_20, item_19)?;
         117  +
                /* JsonSerializerGenerator.kt:515 */
   61    118   
                object_20.finish();
         119  +
                /* SerializerUtil.kt:42 */
   62    120   
            }
         121  +
            /* JsonSerializerGenerator.kt:524 */
   63    122   
        }
         123  +
        /* JsonSerializerGenerator.kt:486 */
   64    124   
        array_18.finish();
         125  +
        /* JsonSerializerGenerator.kt:382 */
   65    126   
    }
         127  +
    /* JsonSerializerGenerator.kt:372 */
   66    128   
    Ok(())
         129  +
    /* JsonSerializerGenerator.kt:358 */
   67    130   
}

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

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

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

@@ -1,1 +43,79 @@
    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_table_replica_auto_scaling_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::update_table_replica_auto_scaling::UpdateTableReplicaAutoScalingInput,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.global_secondary_index_updates {
           9  +
        /* JsonSerializerGenerator.kt:484 */
    7     10   
        let mut array_2 = object.key("GlobalSecondaryIndexUpdates").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_global_secondary_index_auto_scaling_update::ser_global_secondary_index_auto_scaling_update(
   13     21   
                    &mut object_4,
   14     22   
                    item_3,
   15     23   
                )?;
          24  +
                /* JsonSerializerGenerator.kt:515 */
   16     25   
                object_4.finish();
          26  +
                /* SerializerUtil.kt:42 */
   17     27   
            }
          28  +
            /* JsonSerializerGenerator.kt:524 */
   18     29   
        }
          30  +
        /* JsonSerializerGenerator.kt:486 */
   19     31   
        array_2.finish();
          32  +
        /* JsonSerializerGenerator.kt:382 */
   20     33   
    }
          34  +
    /* JsonSerializerGenerator.kt:382 */
   21     35   
    if let Some(var_5) = &input.table_name {
          36  +
        /* JsonSerializerGenerator.kt:423 */
   22     37   
        object.key("TableName").string(var_5.as_str());
          38  +
        /* JsonSerializerGenerator.kt:382 */
   23     39   
    }
          40  +
    /* JsonSerializerGenerator.kt:382 */
   24     41   
    if let Some(var_6) = &input.provisioned_write_capacity_auto_scaling_update {
          42  +
        /* JsonSerializerGenerator.kt:495 */
   25     43   
        #[allow(unused_mut)]
          44  +
        /* JsonSerializerGenerator.kt:496 */
   26     45   
        let mut object_7 = object.key("ProvisionedWriteCapacityAutoScalingUpdate").start_object();
          46  +
        /* JsonSerializerGenerator.kt:375 */
   27     47   
        crate::protocol_serde::shape_auto_scaling_settings_update::ser_auto_scaling_settings_update(&mut object_7, var_6)?;
          48  +
        /* JsonSerializerGenerator.kt:515 */
   28     49   
        object_7.finish();
          50  +
        /* JsonSerializerGenerator.kt:382 */
   29     51   
    }
          52  +
    /* JsonSerializerGenerator.kt:382 */
   30     53   
    if let Some(var_8) = &input.replica_updates {
          54  +
        /* JsonSerializerGenerator.kt:484 */
   31     55   
        let mut array_9 = object.key("ReplicaUpdates").start_array();
          56  +
        /* JsonSerializerGenerator.kt:524 */
   32     57   
        for item_10 in var_8 {
          58  +
            /* SerializerUtil.kt:42 */
   33     59   
            {
          60  +
                /* JsonSerializerGenerator.kt:495 */
   34     61   
                #[allow(unused_mut)]
          62  +
                /* JsonSerializerGenerator.kt:496 */
   35     63   
                let mut object_11 = array_9.value().start_object();
          64  +
                /* JsonSerializerGenerator.kt:375 */
   36     65   
                crate::protocol_serde::shape_replica_auto_scaling_update::ser_replica_auto_scaling_update(&mut object_11, item_10)?;
          66  +
                /* JsonSerializerGenerator.kt:515 */
   37     67   
                object_11.finish();
          68  +
                /* SerializerUtil.kt:42 */
   38     69   
            }
          70  +
            /* JsonSerializerGenerator.kt:524 */
   39     71   
        }
          72  +
        /* JsonSerializerGenerator.kt:486 */
   40     73   
        array_9.finish();
          74  +
        /* JsonSerializerGenerator.kt:382 */
   41     75   
    }
          76  +
    /* JsonSerializerGenerator.kt:372 */
   42     77   
    Ok(())
          78  +
    /* JsonSerializerGenerator.kt:358 */
   43     79   
}

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

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