Client Test

Client Test

rev. dfb5149b65b7bcc09edd15b8e071ad43b5ac5943

Files changed:

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

@@ -1,1 +28,52 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_execute_statement_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::execute_statement::ExecuteStatementInput,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.statement {
           9  +
        /* JsonSerializerGenerator.kt:423 */
    7     10   
        object.key("Statement").string(var_1.as_str());
          11  +
        /* JsonSerializerGenerator.kt:382 */
    8     12   
    }
          13  +
    /* JsonSerializerGenerator.kt:382 */
    9     14   
    if let Some(var_2) = &input.parameters {
          15  +
        /* JsonSerializerGenerator.kt:484 */
   10     16   
        let mut array_3 = object.key("Parameters").start_array();
          17  +
        /* JsonSerializerGenerator.kt:524 */
   11     18   
        for item_4 in var_2 {
          19  +
            /* SerializerUtil.kt:42 */
   12     20   
            {
          21  +
                /* JsonSerializerGenerator.kt:495 */
   13     22   
                #[allow(unused_mut)]
          23  +
                /* JsonSerializerGenerator.kt:496 */
   14     24   
                let mut object_5 = array_3.value().start_object();
          25  +
                /* JsonSerializerGenerator.kt:579 */
   15     26   
                crate::protocol_serde::shape_attribute_value::ser_attribute_value(&mut object_5, item_4)?;
          27  +
                /* JsonSerializerGenerator.kt:515 */
   16     28   
                object_5.finish();
          29  +
                /* SerializerUtil.kt:42 */
   17     30   
            }
          31  +
            /* JsonSerializerGenerator.kt:524 */
   18     32   
        }
          33  +
        /* JsonSerializerGenerator.kt:486 */
   19     34   
        array_3.finish();
          35  +
        /* JsonSerializerGenerator.kt:382 */
   20     36   
    }
          37  +
    /* JsonSerializerGenerator.kt:382 */
   21     38   
    if let Some(var_6) = &input.consistent_read {
          39  +
        /* JsonSerializerGenerator.kt:424 */
   22     40   
        object.key("ConsistentRead").boolean(*var_6);
          41  +
        /* JsonSerializerGenerator.kt:382 */
   23     42   
    }
          43  +
    /* JsonSerializerGenerator.kt:382 */
   24     44   
    if let Some(var_7) = &input.next_token {
          45  +
        /* JsonSerializerGenerator.kt:423 */
   25     46   
        object.key("NextToken").string(var_7.as_str());
          47  +
        /* JsonSerializerGenerator.kt:382 */
   26     48   
    }
          49  +
    /* JsonSerializerGenerator.kt:372 */
   27     50   
    Ok(())
          51  +
    /* JsonSerializerGenerator.kt:358 */
   28     52   
}

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

@@ -1,1 +200,283 @@
    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_execute_transaction_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::execute_transaction::ExecuteTransactionOutput,
    9     11   
    crate::operation::execute_transaction::ExecuteTransactionError,
   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::execute_transaction::ExecuteTransactionError::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::execute_transaction::ExecuteTransactionError::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   
        "IdempotentParameterMismatchException" => crate::operation::execute_transaction::ExecuteTransactionError::IdempotentParameterMismatchError({
          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::IdempotentParameterMismatchErrorBuilder::default();
   27         -
                output = crate::protocol_serde::shape_idempotent_parameter_mismatch_exception::de_idempotent_parameter_mismatch_exception_json_err(
   28         -
                    _response_body,
   29         -
                    output,
   30         -
                )
   31         -
                .map_err(crate::operation::execute_transaction::ExecuteTransactionError::unhandled)?;
   32         -
                let output = output.meta(generic);
   33         -
                output.build()
   34         -
            };
          33  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          34  +
                /* ProtocolParserGenerator.kt:146 */ {
          35  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          36  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::IdempotentParameterMismatchErrorBuilder::default();
          37  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_idempotent_parameter_mismatch_exception::de_idempotent_parameter_mismatch_exception_json_err(_response_body, output).map_err(crate::operation::execute_transaction::ExecuteTransactionError::unhandled)?;
          38  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          39  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
          40  +
                /* ProtocolParserGenerator.kt:146 */}
          41  +
            /* ProtocolParserGenerator.kt:145 */;
          42  +
            /* ProtocolParserGenerator.kt:170 */
   35     43   
            if tmp.message.is_none() {
   36     44   
                tmp.message = _error_message;
   37     45   
            }
          46  +
            /* ProtocolParserGenerator.kt:179 */
   38     47   
            tmp
          48  +
            /* ProtocolParserGenerator.kt:139 */
   39     49   
        }),
          50  +
        /* ProtocolParserGenerator.kt:139 */
   40     51   
        "InternalServerError" => crate::operation::execute_transaction::ExecuteTransactionError::InternalServerError({
          52  +
            /* RustType.kt:516 */
   41     53   
            #[allow(unused_mut)]
   42         -
            let mut tmp = {
   43         -
                #[allow(unused_mut)]
   44         -
                let mut output = crate::types::error::builders::InternalServerErrorBuilder::default();
   45         -
                output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output)
   46         -
                    .map_err(crate::operation::execute_transaction::ExecuteTransactionError::unhandled)?;
   47         -
                let output = output.meta(generic);
   48         -
                output.build()
   49         -
            };
          54  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          55  +
                /* ProtocolParserGenerator.kt:146 */ {
          56  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          57  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::InternalServerErrorBuilder::default();
          58  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output).map_err(crate::operation::execute_transaction::ExecuteTransactionError::unhandled)?;
          59  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          60  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
          61  +
                /* ProtocolParserGenerator.kt:146 */}
          62  +
            /* ProtocolParserGenerator.kt:145 */;
          63  +
            /* ProtocolParserGenerator.kt:170 */
   50     64   
            if tmp.message.is_none() {
   51     65   
                tmp.message = _error_message;
   52     66   
            }
          67  +
            /* ProtocolParserGenerator.kt:179 */
   53     68   
            tmp
          69  +
            /* ProtocolParserGenerator.kt:139 */
   54     70   
        }),
          71  +
        /* ProtocolParserGenerator.kt:139 */
   55     72   
        "ProvisionedThroughputExceededException" => {
   56     73   
            crate::operation::execute_transaction::ExecuteTransactionError::ProvisionedThroughputExceededError({
          74  +
                /* RustType.kt:516 */
   57     75   
                #[allow(unused_mut)]
   58         -
                let mut tmp = {
   59         -
                    #[allow(unused_mut)]
   60         -
                    let mut output = crate::types::error::builders::ProvisionedThroughputExceededErrorBuilder::default();
   61         -
                    output = crate::protocol_serde::shape_provisioned_throughput_exceeded_exception::de_provisioned_throughput_exceeded_exception_json_err(_response_body, output).map_err(crate::operation::execute_transaction::ExecuteTransactionError::unhandled)?;
   62         -
                    let output = output.meta(generic);
   63         -
                    output.build()
   64         -
                };
          76  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          77  +
                /* ProtocolParserGenerator.kt:146 */ {
          78  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          79  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::ProvisionedThroughputExceededErrorBuilder::default();
          80  +
                    /* 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::execute_transaction::ExecuteTransactionError::unhandled)?;
          81  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          82  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
          83  +
                /* ProtocolParserGenerator.kt:146 */}
          84  +
            /* ProtocolParserGenerator.kt:145 */;
          85  +
                /* ProtocolParserGenerator.kt:170 */
   65     86   
                if tmp.message.is_none() {
   66     87   
                    tmp.message = _error_message;
   67     88   
                }
          89  +
                /* ProtocolParserGenerator.kt:179 */
   68     90   
                tmp
          91  +
                /* ProtocolParserGenerator.kt:139 */
   69     92   
            })
   70     93   
        }
          94  +
        /* ProtocolParserGenerator.kt:139 */
   71     95   
        "RequestLimitExceeded" => crate::operation::execute_transaction::ExecuteTransactionError::RequestLimitExceeded({
          96  +
            /* RustType.kt:516 */
   72     97   
            #[allow(unused_mut)]
   73         -
            let mut tmp = {
   74         -
                #[allow(unused_mut)]
   75         -
                let mut output = crate::types::error::builders::RequestLimitExceededBuilder::default();
   76         -
                output = crate::protocol_serde::shape_request_limit_exceeded::de_request_limit_exceeded_json_err(_response_body, output)
   77         -
                    .map_err(crate::operation::execute_transaction::ExecuteTransactionError::unhandled)?;
   78         -
                let output = output.meta(generic);
   79         -
                output.build()
   80         -
            };
          98  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          99  +
                /* ProtocolParserGenerator.kt:146 */ {
         100  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
         101  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::RequestLimitExceededBuilder::default();
         102  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_request_limit_exceeded::de_request_limit_exceeded_json_err(_response_body, output).map_err(crate::operation::execute_transaction::ExecuteTransactionError::unhandled)?;
         103  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
         104  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
         105  +
                /* ProtocolParserGenerator.kt:146 */}
         106  +
            /* ProtocolParserGenerator.kt:145 */;
         107  +
            /* ProtocolParserGenerator.kt:170 */
   81    108   
            if tmp.message.is_none() {
   82    109   
                tmp.message = _error_message;
   83    110   
            }
         111  +
            /* ProtocolParserGenerator.kt:179 */
   84    112   
            tmp
         113  +
            /* ProtocolParserGenerator.kt:139 */
   85    114   
        }),
         115  +
        /* ProtocolParserGenerator.kt:139 */
   86    116   
        "ResourceNotFoundException" => crate::operation::execute_transaction::ExecuteTransactionError::ResourceNotFoundError({
         117  +
            /* RustType.kt:516 */
   87    118   
            #[allow(unused_mut)]
   88         -
            let mut tmp = {
   89         -
                #[allow(unused_mut)]
   90         -
                let mut output = crate::types::error::builders::ResourceNotFoundErrorBuilder::default();
   91         -
                output = crate::protocol_serde::shape_resource_not_found_exception::de_resource_not_found_exception_json_err(_response_body, output)
   92         -
                    .map_err(crate::operation::execute_transaction::ExecuteTransactionError::unhandled)?;
   93         -
                let output = output.meta(generic);
   94         -
                output.build()
   95         -
            };
         119  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
         120  +
                /* ProtocolParserGenerator.kt:146 */ {
         121  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
         122  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::ResourceNotFoundErrorBuilder::default();
         123  +
                    /* 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::execute_transaction::ExecuteTransactionError::unhandled)?;
         124  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
         125  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
         126  +
                /* ProtocolParserGenerator.kt:146 */}
         127  +
            /* ProtocolParserGenerator.kt:145 */;
         128  +
            /* ProtocolParserGenerator.kt:170 */
   96    129   
            if tmp.message.is_none() {
   97    130   
                tmp.message = _error_message;
   98    131   
            }
         132  +
            /* ProtocolParserGenerator.kt:179 */
   99    133   
            tmp
         134  +
            /* ProtocolParserGenerator.kt:139 */
  100    135   
        }),
         136  +
        /* ProtocolParserGenerator.kt:139 */
  101    137   
        "TransactionCanceledException" => crate::operation::execute_transaction::ExecuteTransactionError::TransactionCanceledError({
         138  +
            /* RustType.kt:516 */
  102    139   
            #[allow(unused_mut)]
  103         -
            let mut tmp = {
  104         -
                #[allow(unused_mut)]
  105         -
                let mut output = crate::types::error::builders::TransactionCanceledErrorBuilder::default();
  106         -
                output =
  107         -
                    crate::protocol_serde::shape_transaction_canceled_exception::de_transaction_canceled_exception_json_err(_response_body, output)
  108         -
                        .map_err(crate::operation::execute_transaction::ExecuteTransactionError::unhandled)?;
  109         -
                let output = output.meta(generic);
  110         -
                output.build()
  111         -
            };
         140  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
         141  +
                /* ProtocolParserGenerator.kt:146 */ {
         142  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
         143  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::TransactionCanceledErrorBuilder::default();
         144  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_transaction_canceled_exception::de_transaction_canceled_exception_json_err(_response_body, output).map_err(crate::operation::execute_transaction::ExecuteTransactionError::unhandled)?;
         145  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
         146  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
         147  +
                /* ProtocolParserGenerator.kt:146 */}
         148  +
            /* ProtocolParserGenerator.kt:145 */;
         149  +
            /* ProtocolParserGenerator.kt:170 */
  112    150   
            if tmp.message.is_none() {
  113    151   
                tmp.message = _error_message;
  114    152   
            }
         153  +
            /* ProtocolParserGenerator.kt:179 */
  115    154   
            tmp
         155  +
            /* ProtocolParserGenerator.kt:139 */
  116    156   
        }),
         157  +
        /* ProtocolParserGenerator.kt:139 */
  117    158   
        "TransactionInProgressException" => crate::operation::execute_transaction::ExecuteTransactionError::TransactionInProgressError({
         159  +
            /* RustType.kt:516 */
  118    160   
            #[allow(unused_mut)]
  119         -
            let mut tmp = {
  120         -
                #[allow(unused_mut)]
  121         -
                let mut output = crate::types::error::builders::TransactionInProgressErrorBuilder::default();
  122         -
                output = crate::protocol_serde::shape_transaction_in_progress_exception::de_transaction_in_progress_exception_json_err(
  123         -
                    _response_body,
  124         -
                    output,
  125         -
                )
  126         -
                .map_err(crate::operation::execute_transaction::ExecuteTransactionError::unhandled)?;
  127         -
                let output = output.meta(generic);
  128         -
                output.build()
  129         -
            };
         161  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
         162  +
                /* ProtocolParserGenerator.kt:146 */ {
         163  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
         164  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::TransactionInProgressErrorBuilder::default();
         165  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_transaction_in_progress_exception::de_transaction_in_progress_exception_json_err(_response_body, output).map_err(crate::operation::execute_transaction::ExecuteTransactionError::unhandled)?;
         166  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
         167  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
         168  +
                /* ProtocolParserGenerator.kt:146 */}
         169  +
            /* ProtocolParserGenerator.kt:145 */;
         170  +
            /* ProtocolParserGenerator.kt:170 */
  130    171   
            if tmp.message.is_none() {
  131    172   
                tmp.message = _error_message;
  132    173   
            }
         174  +
            /* ProtocolParserGenerator.kt:179 */
  133    175   
            tmp
         176  +
            /* ProtocolParserGenerator.kt:139 */
  134    177   
        }),
  135         -
        _ => crate::operation::execute_transaction::ExecuteTransactionError::generic(generic),
         178  +
        /* ProtocolParserGenerator.kt:182 */
         179  +
        _ => crate::operation::execute_transaction::ExecuteTransactionError::generic(generic), /* ProtocolParserGenerator.kt:133 */
  136    180   
    })
         181  +
    /* ProtocolParserGenerator.kt:99 */
  137    182   
}
  138    183   
         184  +
/* RustType.kt:516 */
  139    185   
#[allow(clippy::unnecessary_wraps)]
         186  +
/* ProtocolParserGenerator.kt:71 */
  140    187   
pub fn de_execute_transaction_http_response(
  141    188   
    _response_status: u16,
  142    189   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
  143    190   
    _response_body: &[u8],
  144    191   
) -> std::result::Result<
  145    192   
    crate::operation::execute_transaction::ExecuteTransactionOutput,
  146    193   
    crate::operation::execute_transaction::ExecuteTransactionError,
  147    194   
> {
         195  +
    /* ProtocolParserGenerator.kt:77 */
  148    196   
    Ok({
         197  +
        /* RustType.kt:516 */
  149    198   
        #[allow(unused_mut)]
         199  +
        /* ProtocolParserGenerator.kt:240 */
  150    200   
        let mut output = crate::operation::execute_transaction::builders::ExecuteTransactionOutputBuilder::default();
         201  +
        /* ProtocolParserGenerator.kt:247 */
  151    202   
        output = crate::protocol_serde::shape_execute_transaction::de_execute_transaction(_response_body, output)
  152    203   
            .map_err(crate::operation::execute_transaction::ExecuteTransactionError::unhandled)?;
         204  +
        /* ClientBuilderInstantiator.kt:56 */
  153    205   
        output.build()
         206  +
        /* ProtocolParserGenerator.kt:77 */
  154    207   
    })
         208  +
    /* ProtocolParserGenerator.kt:71 */
  155    209   
}
  156    210   
         211  +
/* JsonSerializerGenerator.kt:287 */
  157    212   
pub fn ser_execute_transaction_input(
  158    213   
    input: &crate::operation::execute_transaction::ExecuteTransactionInput,
  159    214   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
         215  +
    /* JsonSerializerGenerator.kt:291 */
  160    216   
    let mut out = String::new();
         217  +
    /* JsonSerializerGenerator.kt:292 */
  161    218   
    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
         219  +
    /* JsonSerializerGenerator.kt:375 */
  162    220   
    crate::protocol_serde::shape_execute_transaction_input::ser_execute_transaction_input_input(&mut object, input)?;
         221  +
    /* JsonSerializerGenerator.kt:295 */
  163    222   
    object.finish();
         223  +
    /* JsonSerializerGenerator.kt:296 */
  164    224   
    Ok(::aws_smithy_types::body::SdkBody::from(out))
         225  +
    /* JsonSerializerGenerator.kt:287 */
  165    226   
}
  166    227   
         228  +
/* JsonParserGenerator.kt:148 */
  167    229   
pub(crate) fn de_execute_transaction(
  168    230   
    value: &[u8],
  169    231   
    mut builder: crate::operation::execute_transaction::builders::ExecuteTransactionOutputBuilder,
  170    232   
) -> ::std::result::Result<
  171    233   
    crate::operation::execute_transaction::builders::ExecuteTransactionOutputBuilder,
  172    234   
    ::aws_smithy_json::deserialize::error::DeserializeError,
  173    235   
> {
         236  +
    /* JsonParserGenerator.kt:153 */
  174    237   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
  175    238   
    let tokens = &mut tokens_owned;
  176    239   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
         240  +
    /* JsonParserGenerator.kt:684 */
  177    241   
    loop {
         242  +
        /* JsonParserGenerator.kt:685 */
  178    243   
        match tokens.next().transpose()? {
  179         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
  180         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
  181         -
                "Responses" => {
  182         -
                    builder = builder.set_responses(crate::protocol_serde::shape_item_response_list::de_item_response_list(tokens)?);
         244  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
         245  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
         246  +
                /* JsonParserGenerator.kt:260 */
         247  +
                match key.to_unescaped()?.as_ref() {
         248  +
                    /* JsonParserGenerator.kt:262 */
         249  +
                    "Responses" => {
         250  +
                        /* JsonParserGenerator.kt:265 */
         251  +
                        builder = builder.set_responses(
         252  +
                            /* JsonParserGenerator.kt:451 */
         253  +
                            crate::protocol_serde::shape_item_response_list::de_item_response_list(tokens)?, /* JsonParserGenerator.kt:265 */
         254  +
                        );
         255  +
                        /* JsonParserGenerator.kt:262 */
         256  +
                    }
         257  +
                    /* JsonParserGenerator.kt:290 */
         258  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
  183    259   
                }
  184         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
  185         -
            },
         260  +
                /* JsonParserGenerator.kt:686 */
         261  +
            }
         262  +
            /* JsonParserGenerator.kt:695 */
  186    263   
            other => {
  187    264   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
  188    265   
                    "expected object key or end object, found: {:?}",
  189    266   
                    other
  190    267   
                )))
  191         -
            }
         268  +
            } /* JsonParserGenerator.kt:685 */
  192    269   
        }
         270  +
        /* JsonParserGenerator.kt:684 */
  193    271   
    }
         272  +
    /* JsonParserGenerator.kt:250 */
  194    273   
    if tokens.next().is_some() {
         274  +
        /* JsonParserGenerator.kt:251 */
  195    275   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
  196    276   
            "found more JSON tokens after completing parsing",
  197    277   
        ));
         278  +
        /* JsonParserGenerator.kt:250 */
  198    279   
    }
         280  +
    /* JsonParserGenerator.kt:163 */
  199    281   
    Ok(builder)
         282  +
    /* JsonParserGenerator.kt:148 */
  200    283   
}

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

@@ -1,1 +22,40 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_execute_transaction_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::execute_transaction::ExecuteTransactionInput,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.transact_statements {
           9  +
        /* JsonSerializerGenerator.kt:484 */
    7     10   
        let mut array_2 = object.key("TransactStatements").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_parameterized_statement::ser_parameterized_statement(&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.client_request_token {
          33  +
        /* JsonSerializerGenerator.kt:423 */
   19     34   
        object.key("ClientRequestToken").string(var_5.as_str());
          35  +
        /* JsonSerializerGenerator.kt:382 */
   20     36   
    }
          37  +
    /* JsonSerializerGenerator.kt:372 */
   21     38   
    Ok(())
          39  +
    /* JsonSerializerGenerator.kt:358 */
   22     40   
}

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_expected_attribute_value.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_expected_attribute_value(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::types::ExpectedAttributeValue,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.value {
           9  +
        /* JsonSerializerGenerator.kt:495 */
    7     10   
        #[allow(unused_mut)]
          11  +
        /* JsonSerializerGenerator.kt:496 */
    8     12   
        let mut object_2 = object.key("Value").start_object();
          13  +
        /* JsonSerializerGenerator.kt:579 */
    9     14   
        crate::protocol_serde::shape_attribute_value::ser_attribute_value(&mut object_2, var_1)?;
          15  +
        /* JsonSerializerGenerator.kt:515 */
   10     16   
        object_2.finish();
          17  +
        /* JsonSerializerGenerator.kt:382 */
   11     18   
    }
          19  +
    /* JsonSerializerGenerator.kt:382 */
   12     20   
    if let Some(var_3) = &input.exists {
          21  +
        /* JsonSerializerGenerator.kt:424 */
   13     22   
        object.key("Exists").boolean(*var_3);
          23  +
        /* JsonSerializerGenerator.kt:382 */
   14     24   
    }
          25  +
    /* JsonSerializerGenerator.kt:382 */
   15     26   
    if let Some(var_4) = &input.comparison_operator {
          27  +
        /* JsonSerializerGenerator.kt:423 */
   16     28   
        object.key("ComparisonOperator").string(var_4.as_str());
          29  +
        /* JsonSerializerGenerator.kt:382 */
   17     30   
    }
          31  +
    /* JsonSerializerGenerator.kt:382 */
   18     32   
    if let Some(var_5) = &input.attribute_value_list {
          33  +
        /* JsonSerializerGenerator.kt:484 */
   19     34   
        let mut array_6 = object.key("AttributeValueList").start_array();
          35  +
        /* JsonSerializerGenerator.kt:524 */
   20     36   
        for item_7 in var_5 {
          37  +
            /* SerializerUtil.kt:42 */
   21     38   
            {
          39  +
                /* JsonSerializerGenerator.kt:495 */
   22     40   
                #[allow(unused_mut)]
          41  +
                /* JsonSerializerGenerator.kt:496 */
   23     42   
                let mut object_8 = array_6.value().start_object();
          43  +
                /* JsonSerializerGenerator.kt:579 */
   24     44   
                crate::protocol_serde::shape_attribute_value::ser_attribute_value(&mut object_8, item_7)?;
          45  +
                /* JsonSerializerGenerator.kt:515 */
   25     46   
                object_8.finish();
          47  +
                /* SerializerUtil.kt:42 */
   26     48   
            }
          49  +
            /* JsonSerializerGenerator.kt:524 */
   27     50   
        }
          51  +
        /* JsonSerializerGenerator.kt:486 */
   28     52   
        array_6.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_export_conflict_exception.rs

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

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

@@ -1,1 +163,308 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonParserGenerator.kt:516 */
    2      3   
pub(crate) fn de_export_description<'a, I>(
    3      4   
    tokens: &mut ::std::iter::Peekable<I>,
    4      5   
) -> ::std::result::Result<Option<crate::types::ExportDescription>, ::aws_smithy_json::deserialize::error::DeserializeError>
    5      6   
where
    6      7   
    I: Iterator<Item = Result<::aws_smithy_json::deserialize::Token<'a>, ::aws_smithy_json::deserialize::error::DeserializeError>>,
    7      8   
{
           9  +
    /* JsonParserGenerator.kt:712 */
    8     10   
    match tokens.next().transpose()? {
    9         -
        Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
          11  +
        /* JsonParserGenerator.kt:713 */ Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
   10     12   
        Some(::aws_smithy_json::deserialize::Token::StartObject { .. }) => {
          13  +
            /* RustType.kt:516 */
   11     14   
            #[allow(unused_mut)]
          15  +
            /* JsonParserGenerator.kt:526 */
   12     16   
            let mut builder = crate::types::builders::ExportDescriptionBuilder::default();
          17  +
            /* JsonParserGenerator.kt:684 */
   13     18   
            loop {
          19  +
                /* JsonParserGenerator.kt:685 */
   14     20   
                match tokens.next().transpose()? {
   15         -
                    Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   16         -
                    Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
   17         -
                        "ExportArn" => {
   18         -
                            builder = builder.set_export_arn(
   19         -
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   20         -
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   21         -
                                    .transpose()?,
   22         -
                            );
          21  +
                    /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
          22  +
                    Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
          23  +
                        /* JsonParserGenerator.kt:260 */
          24  +
                        match key.to_unescaped()?.as_ref() {
          25  +
                            /* JsonParserGenerator.kt:262 */
          26  +
                            "ExportArn" => {
          27  +
                                /* JsonParserGenerator.kt:265 */
          28  +
                                builder = builder.set_export_arn(
          29  +
                                    /* JsonParserGenerator.kt:354 */
          30  +
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
          31  +
                                        .map(|s|
          32  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          33  +
                                            /* JsonParserGenerator.kt:348 */u.into_owned()
          34  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
          35  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
          36  +
                                );
          37  +
                                /* JsonParserGenerator.kt:262 */
          38  +
                            }
          39  +
                            /* JsonParserGenerator.kt:262 */
          40  +
                            "ExportStatus" => {
          41  +
                                /* JsonParserGenerator.kt:265 */
          42  +
                                builder = builder.set_export_status(
          43  +
                                    /* JsonParserGenerator.kt:354 */
          44  +
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
          45  +
                                        .map(|s|
          46  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          47  +
                                            /* JsonParserGenerator.kt:345 */crate::types::ExportStatus::from(u.as_ref())
          48  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
          49  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
          50  +
                                );
          51  +
                                /* JsonParserGenerator.kt:262 */
          52  +
                            }
          53  +
                            /* JsonParserGenerator.kt:262 */
          54  +
                            "StartTime" => {
          55  +
                                /* JsonParserGenerator.kt:265 */
          56  +
                                builder = builder.set_start_time(
          57  +
                                    /* JsonParserGenerator.kt:384 */
          58  +
                                    ::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
          59  +
                                        tokens.next(),
          60  +
                                        ::aws_smithy_types::date_time::Format::EpochSeconds,
          61  +
                                    )?, /* JsonParserGenerator.kt:265 */
          62  +
                                );
          63  +
                                /* JsonParserGenerator.kt:262 */
          64  +
                            }
          65  +
                            /* JsonParserGenerator.kt:262 */
          66  +
                            "EndTime" => {
          67  +
                                /* JsonParserGenerator.kt:265 */
          68  +
                                builder = builder.set_end_time(
          69  +
                                    /* JsonParserGenerator.kt:384 */
          70  +
                                    ::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
          71  +
                                        tokens.next(),
          72  +
                                        ::aws_smithy_types::date_time::Format::EpochSeconds,
          73  +
                                    )?, /* JsonParserGenerator.kt:265 */
          74  +
                                );
          75  +
                                /* JsonParserGenerator.kt:262 */
          76  +
                            }
          77  +
                            /* JsonParserGenerator.kt:262 */
          78  +
                            "ExportManifest" => {
          79  +
                                /* JsonParserGenerator.kt:265 */
          80  +
                                builder = builder.set_export_manifest(
          81  +
                                    /* JsonParserGenerator.kt:354 */
          82  +
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
          83  +
                                        .map(|s|
          84  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          85  +
                                            /* JsonParserGenerator.kt:348 */u.into_owned()
          86  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
          87  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
          88  +
                                );
          89  +
                                /* JsonParserGenerator.kt:262 */
          90  +
                            }
          91  +
                            /* JsonParserGenerator.kt:262 */
          92  +
                            "TableArn" => {
          93  +
                                /* JsonParserGenerator.kt:265 */
          94  +
                                builder = builder.set_table_arn(
          95  +
                                    /* JsonParserGenerator.kt:354 */
          96  +
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
          97  +
                                        .map(|s|
          98  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          99  +
                                            /* JsonParserGenerator.kt:348 */u.into_owned()
         100  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
         101  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
         102  +
                                );
         103  +
                                /* JsonParserGenerator.kt:262 */
         104  +
                            }
         105  +
                            /* JsonParserGenerator.kt:262 */
         106  +
                            "TableId" => {
         107  +
                                /* JsonParserGenerator.kt:265 */
         108  +
                                builder = builder.set_table_id(
         109  +
                                    /* JsonParserGenerator.kt:354 */
         110  +
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
         111  +
                                        .map(|s|
         112  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
         113  +
                                            /* JsonParserGenerator.kt:348 */u.into_owned()
         114  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
         115  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
         116  +
                                );
         117  +
                                /* JsonParserGenerator.kt:262 */
         118  +
                            }
         119  +
                            /* JsonParserGenerator.kt:262 */
         120  +
                            "ExportTime" => {
         121  +
                                /* JsonParserGenerator.kt:265 */
         122  +
                                builder = builder.set_export_time(
         123  +
                                    /* JsonParserGenerator.kt:384 */
         124  +
                                    ::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
         125  +
                                        tokens.next(),
         126  +
                                        ::aws_smithy_types::date_time::Format::EpochSeconds,
         127  +
                                    )?, /* JsonParserGenerator.kt:265 */
         128  +
                                );
         129  +
                                /* JsonParserGenerator.kt:262 */
         130  +
                            }
         131  +
                            /* JsonParserGenerator.kt:262 */
         132  +
                            "ClientToken" => {
         133  +
                                /* JsonParserGenerator.kt:265 */
         134  +
                                builder = builder.set_client_token(
         135  +
                                    /* JsonParserGenerator.kt:354 */
         136  +
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
         137  +
                                        .map(|s|
         138  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
         139  +
                                            /* JsonParserGenerator.kt:348 */u.into_owned()
         140  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
         141  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
         142  +
                                );
         143  +
                                /* JsonParserGenerator.kt:262 */
         144  +
                            }
         145  +
                            /* JsonParserGenerator.kt:262 */
         146  +
                            "S3Bucket" => {
         147  +
                                /* JsonParserGenerator.kt:265 */
         148  +
                                builder = builder.set_s3_bucket(
         149  +
                                    /* JsonParserGenerator.kt:354 */
         150  +
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
         151  +
                                        .map(|s|
         152  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
         153  +
                                            /* JsonParserGenerator.kt:348 */u.into_owned()
         154  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
         155  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
         156  +
                                );
         157  +
                                /* JsonParserGenerator.kt:262 */
         158  +
                            }
         159  +
                            /* JsonParserGenerator.kt:262 */
         160  +
                            "S3BucketOwner" => {
         161  +
                                /* JsonParserGenerator.kt:265 */
         162  +
                                builder = builder.set_s3_bucket_owner(
         163  +
                                    /* JsonParserGenerator.kt:354 */
         164  +
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
         165  +
                                        .map(|s|
         166  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
         167  +
                                            /* JsonParserGenerator.kt:348 */u.into_owned()
         168  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
         169  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
         170  +
                                );
         171  +
                                /* JsonParserGenerator.kt:262 */
         172  +
                            }
         173  +
                            /* JsonParserGenerator.kt:262 */
         174  +
                            "S3Prefix" => {
         175  +
                                /* JsonParserGenerator.kt:265 */
         176  +
                                builder = builder.set_s3_prefix(
         177  +
                                    /* JsonParserGenerator.kt:354 */
         178  +
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
         179  +
                                        .map(|s|
         180  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
         181  +
                                            /* JsonParserGenerator.kt:348 */u.into_owned()
         182  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
         183  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
         184  +
                                );
         185  +
                                /* JsonParserGenerator.kt:262 */
         186  +
                            }
         187  +
                            /* JsonParserGenerator.kt:262 */
         188  +
                            "S3SseAlgorithm" => {
         189  +
                                /* JsonParserGenerator.kt:265 */
         190  +
                                builder = builder.set_s3_sse_algorithm(
         191  +
                                    /* JsonParserGenerator.kt:354 */
         192  +
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
         193  +
                                        .map(|s|
         194  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
         195  +
                                            /* JsonParserGenerator.kt:345 */crate::types::S3SseAlgorithm::from(u.as_ref())
         196  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
         197  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
         198  +
                                );
         199  +
                                /* JsonParserGenerator.kt:262 */
         200  +
                            }
         201  +
                            /* JsonParserGenerator.kt:262 */
         202  +
                            "S3SseKmsKeyId" => {
         203  +
                                /* JsonParserGenerator.kt:265 */
         204  +
                                builder = builder.set_s3_sse_kms_key_id(
         205  +
                                    /* JsonParserGenerator.kt:354 */
         206  +
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
         207  +
                                        .map(|s|
         208  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
         209  +
                                            /* JsonParserGenerator.kt:348 */u.into_owned()
         210  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
         211  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
         212  +
                                );
         213  +
                                /* JsonParserGenerator.kt:262 */
         214  +
                            }
         215  +
                            /* JsonParserGenerator.kt:262 */
         216  +
                            "FailureCode" => {
         217  +
                                /* JsonParserGenerator.kt:265 */
         218  +
                                builder = builder.set_failure_code(
         219  +
                                    /* JsonParserGenerator.kt:354 */
         220  +
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
         221  +
                                        .map(|s|
         222  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
         223  +
                                            /* JsonParserGenerator.kt:348 */u.into_owned()
         224  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
         225  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
         226  +
                                );
         227  +
                                /* JsonParserGenerator.kt:262 */
         228  +
                            }
         229  +
                            /* JsonParserGenerator.kt:262 */
         230  +
                            "FailureMessage" => {
         231  +
                                /* JsonParserGenerator.kt:265 */
         232  +
                                builder = builder.set_failure_message(
         233  +
                                    /* JsonParserGenerator.kt:354 */
         234  +
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
         235  +
                                        .map(|s|
         236  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
         237  +
                                            /* JsonParserGenerator.kt:348 */u.into_owned()
         238  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
         239  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
         240  +
                                );
         241  +
                                /* JsonParserGenerator.kt:262 */
         242  +
                            }
         243  +
                            /* JsonParserGenerator.kt:262 */
         244  +
                            "ExportFormat" => {
         245  +
                                /* JsonParserGenerator.kt:265 */
         246  +
                                builder = builder.set_export_format(
         247  +
                                    /* JsonParserGenerator.kt:354 */
         248  +
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
         249  +
                                        .map(|s|
         250  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
         251  +
                                            /* JsonParserGenerator.kt:345 */crate::types::ExportFormat::from(u.as_ref())
         252  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
         253  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
         254  +
                                );
         255  +
                                /* JsonParserGenerator.kt:262 */
         256  +
                            }
         257  +
                            /* JsonParserGenerator.kt:262 */
         258  +
                            "BilledSizeBytes" => {
         259  +
                                /* JsonParserGenerator.kt:265 */
         260  +
                                builder = builder.set_billed_size_bytes(
         261  +
                                    /* JsonParserGenerator.kt:365 */
         262  +
                                    ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
         263  +
                                        .map(i64::try_from)
         264  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
         265  +
                                );
         266  +
                                /* JsonParserGenerator.kt:262 */
         267  +
                            }
         268  +
                            /* JsonParserGenerator.kt:262 */
         269  +
                            "ItemCount" => {
         270  +
                                /* JsonParserGenerator.kt:265 */
         271  +
                                builder = builder.set_item_count(
         272  +
                                    /* JsonParserGenerator.kt:365 */
         273  +
                                    ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
         274  +
                                        .map(i64::try_from)
         275  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
         276  +
                                );
         277  +
                                /* JsonParserGenerator.kt:262 */
         278  +
                            }
         279  +
                            /* JsonParserGenerator.kt:290 */
         280  +
                            _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
   23    281   
                        }
   24         -
                        "ExportStatus" => {
   25         -
                            builder = builder.set_export_status(
   26         -
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   27         -
                                    .map(|s| s.to_unescaped().map(|u| crate::types::ExportStatus::from(u.as_ref())))
   28         -
                                    .transpose()?,
   29         -
                            );
   30         -
                        }
   31         -
                        "StartTime" => {
   32         -
                            builder = builder.set_start_time(::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
   33         -
                                tokens.next(),
   34         -
                                ::aws_smithy_types::date_time::Format::EpochSeconds,
   35         -
                            )?);
   36         -
                        }
   37         -
                        "EndTime" => {
   38         -
                            builder = builder.set_end_time(::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
   39         -
                                tokens.next(),
   40         -
                                ::aws_smithy_types::date_time::Format::EpochSeconds,
   41         -
                            )?);
   42         -
                        }
   43         -
                        "ExportManifest" => {
   44         -
                            builder = builder.set_export_manifest(
   45         -
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   46         -
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   47         -
                                    .transpose()?,
   48         -
                            );
   49         -
                        }
   50         -
                        "TableArn" => {
   51         -
                            builder = builder.set_table_arn(
   52         -
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   53         -
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   54         -
                                    .transpose()?,
   55         -
                            );
   56         -
                        }
   57         -
                        "TableId" => {
   58         -
                            builder = builder.set_table_id(
   59         -
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   60         -
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   61         -
                                    .transpose()?,
   62         -
                            );
   63         -
                        }
   64         -
                        "ExportTime" => {
   65         -
                            builder = builder.set_export_time(::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
   66         -
                                tokens.next(),
   67         -
                                ::aws_smithy_types::date_time::Format::EpochSeconds,
   68         -
                            )?);
   69         -
                        }
   70         -
                        "ClientToken" => {
   71         -
                            builder = builder.set_client_token(
   72         -
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   73         -
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   74         -
                                    .transpose()?,
   75         -
                            );
   76         -
                        }
   77         -
                        "S3Bucket" => {
   78         -
                            builder = builder.set_s3_bucket(
   79         -
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   80         -
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   81         -
                                    .transpose()?,
   82         -
                            );
   83         -
                        }
   84         -
                        "S3BucketOwner" => {
   85         -
                            builder = builder.set_s3_bucket_owner(
   86         -
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   87         -
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   88         -
                                    .transpose()?,
   89         -
                            );
   90         -
                        }
   91         -
                        "S3Prefix" => {
   92         -
                            builder = builder.set_s3_prefix(
   93         -
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   94         -
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   95         -
                                    .transpose()?,
   96         -
                            );
   97         -
                        }
   98         -
                        "S3SseAlgorithm" => {
   99         -
                            builder = builder.set_s3_sse_algorithm(
  100         -
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
  101         -
                                    .map(|s| s.to_unescaped().map(|u| crate::types::S3SseAlgorithm::from(u.as_ref())))
  102         -
                                    .transpose()?,
  103         -
                            );
  104         -
                        }
  105         -
                        "S3SseKmsKeyId" => {
  106         -
                            builder = builder.set_s3_sse_kms_key_id(
  107         -
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
  108         -
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
  109         -
                                    .transpose()?,
  110         -
                            );
  111         -
                        }
  112         -
                        "FailureCode" => {
  113         -
                            builder = builder.set_failure_code(
  114         -
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
  115         -
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
  116         -
                                    .transpose()?,
  117         -
                            );
  118         -
                        }
  119         -
                        "FailureMessage" => {
  120         -
                            builder = builder.set_failure_message(
  121         -
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
  122         -
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
  123         -
                                    .transpose()?,
  124         -
                            );
  125         -
                        }
  126         -
                        "ExportFormat" => {
  127         -
                            builder = builder.set_export_format(
  128         -
                                ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
  129         -
                                    .map(|s| s.to_unescaped().map(|u| crate::types::ExportFormat::from(u.as_ref())))
  130         -
                                    .transpose()?,
  131         -
                            );
  132         -
                        }
  133         -
                        "BilledSizeBytes" => {
  134         -
                            builder = builder.set_billed_size_bytes(
  135         -
                                ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
  136         -
                                    .map(i64::try_from)
  137         -
                                    .transpose()?,
  138         -
                            );
  139         -
                        }
  140         -
                        "ItemCount" => {
  141         -
                            builder = builder.set_item_count(
  142         -
                                ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
  143         -
                                    .map(i64::try_from)
  144         -
                                    .transpose()?,
  145         -
                            );
  146         -
                        }
  147         -
                        _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
  148         -
                    },
         282  +
                        /* JsonParserGenerator.kt:686 */
         283  +
                    }
         284  +
                    /* JsonParserGenerator.kt:695 */
  149    285   
                    other => {
  150    286   
                        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
  151    287   
                            "expected object key or end object, found: {:?}",
  152    288   
                            other
  153    289   
                        )))
  154         -
                    }
         290  +
                    } /* JsonParserGenerator.kt:685 */
  155    291   
                }
         292  +
                /* JsonParserGenerator.kt:684 */
  156    293   
            }
         294  +
            /* JsonParserGenerator.kt:540 */
  157    295   
            Ok(Some(builder.build()))
         296  +
            /* JsonParserGenerator.kt:713 */
  158    297   
        }
  159         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
  160         -
            "expected start object or null",
  161         -
        )),
         298  +
        /* JsonParserGenerator.kt:722 */
         299  +
        _ => {
         300  +
            /* JsonParserGenerator.kt:723 */
         301  +
            Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
         302  +
                "expected start object or null",
         303  +
            ))
         304  +
            /* JsonParserGenerator.kt:722 */
         305  +
        } /* JsonParserGenerator.kt:712 */
  162    306   
    }
         307  +
    /* JsonParserGenerator.kt:516 */
  163    308   
}

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

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

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

@@ -1,1 +32,55 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonParserGenerator.kt:398 */
    2      3   
pub(crate) fn de_export_summaries<'a, I>(
    3      4   
    tokens: &mut ::std::iter::Peekable<I>,
    4      5   
) -> ::std::result::Result<Option<::std::vec::Vec<crate::types::ExportSummary>>, ::aws_smithy_json::deserialize::error::DeserializeError>
    5      6   
where
    6      7   
    I: Iterator<Item = Result<::aws_smithy_json::deserialize::Token<'a>, ::aws_smithy_json::deserialize::error::DeserializeError>>,
    7      8   
{
           9  +
    /* JsonParserGenerator.kt:712 */
    8     10   
    match tokens.next().transpose()? {
    9         -
        Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
          11  +
        /* JsonParserGenerator.kt:713 */ Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
   10     12   
        Some(::aws_smithy_json::deserialize::Token::StartArray { .. }) => {
          13  +
            /* JsonParserGenerator.kt:407 */
   11     14   
            let mut items = Vec::new();
          15  +
            /* JsonParserGenerator.kt:408 */
   12     16   
            loop {
          17  +
                /* JsonParserGenerator.kt:409 */
   13     18   
                match tokens.peek() {
          19  +
                    /* JsonParserGenerator.kt:410 */
   14     20   
                    Some(Ok(::aws_smithy_json::deserialize::Token::EndArray { .. })) => {
          21  +
                        /* JsonParserGenerator.kt:411 */
   15     22   
                        tokens.next().transpose().unwrap();
   16     23   
                        break;
          24  +
                        /* JsonParserGenerator.kt:410 */
   17     25   
                    }
          26  +
                    /* JsonParserGenerator.kt:413 */
   18     27   
                    _ => {
   19         -
                        let value = crate::protocol_serde::shape_export_summary::de_export_summary(tokens)?;
          28  +
                        /* JsonParserGenerator.kt:419 */
          29  +
                        let value =
          30  +
                            /* JsonParserGenerator.kt:544 */crate::protocol_serde::shape_export_summary::de_export_summary(tokens)?
          31  +
                        /* JsonParserGenerator.kt:419 */;
          32  +
                        /* JsonParserGenerator.kt:422 */
   20     33   
                        if let Some(value) = value {
   21     34   
                            items.push(value);
   22     35   
                        }
   23         -
                    }
          36  +
                        /* JsonParserGenerator.kt:413 */
          37  +
                    } /* JsonParserGenerator.kt:409 */
   24     38   
                }
          39  +
                /* JsonParserGenerator.kt:408 */
   25     40   
            }
          41  +
            /* JsonParserGenerator.kt:446 */
   26     42   
            Ok(Some(items))
          43  +
            /* JsonParserGenerator.kt:713 */
   27     44   
        }
   28         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   29         -
            "expected start array or null",
   30         -
        )),
          45  +
        /* JsonParserGenerator.kt:722 */
          46  +
        _ => {
          47  +
            /* JsonParserGenerator.kt:723 */
          48  +
            Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
          49  +
                "expected start array or null",
          50  +
            ))
          51  +
            /* JsonParserGenerator.kt:722 */
          52  +
        } /* JsonParserGenerator.kt:712 */
   31     53   
    }
          54  +
    /* JsonParserGenerator.kt:398 */
   32     55   
}

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

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

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

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