Client Test

Client Test

rev. dfb5149b65b7bcc09edd15b8e071ad43b5ac5943 (ignoring whitespace)

Files changed:

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

@@ -1,1 +22,37 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_replica_global_secondary_index_settings_update(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::types::ReplicaGlobalSecondaryIndexSettingsUpdate,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* SerializerUtil.kt:42 */
    6      8   
    {
           9  +
        /* JsonSerializerGenerator.kt:423 */
    7     10   
        object.key("IndexName").string(input.index_name.as_str());
          11  +
        /* SerializerUtil.kt:42 */
    8     12   
    }
          13  +
    /* JsonSerializerGenerator.kt:382 */
    9     14   
    if let Some(var_1) = &input.provisioned_read_capacity_units {
          15  +
        /* JsonSerializerGenerator.kt:432 */
   10     16   
        object.key("ProvisionedReadCapacityUnits").number(
   11     17   
            #[allow(clippy::useless_conversion)]
   12     18   
            ::aws_smithy_types::Number::NegInt((*var_1).into()),
   13     19   
        );
          20  +
        /* JsonSerializerGenerator.kt:382 */
   14     21   
    }
          22  +
    /* JsonSerializerGenerator.kt:382 */
   15     23   
    if let Some(var_2) = &input.provisioned_read_capacity_auto_scaling_settings_update {
          24  +
        /* JsonSerializerGenerator.kt:495 */
   16     25   
        #[allow(unused_mut)]
          26  +
        /* JsonSerializerGenerator.kt:496 */
   17     27   
        let mut object_3 = object.key("ProvisionedReadCapacityAutoScalingSettingsUpdate").start_object();
          28  +
        /* JsonSerializerGenerator.kt:375 */
   18     29   
        crate::protocol_serde::shape_auto_scaling_settings_update::ser_auto_scaling_settings_update(&mut object_3, var_2)?;
          30  +
        /* JsonSerializerGenerator.kt:515 */
   19     31   
        object_3.finish();
          32  +
        /* JsonSerializerGenerator.kt:382 */
   20     33   
    }
          34  +
    /* JsonSerializerGenerator.kt:372 */
   21     35   
    Ok(())
          36  +
    /* JsonSerializerGenerator.kt:358 */
   22     37   
}

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_replica_list.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_replica_list<'a, I>(
    3      4   
    tokens: &mut ::std::iter::Peekable<I>,
    4      5   
) -> ::std::result::Result<Option<::std::vec::Vec<crate::types::Replica>>, ::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_replica::de_replica(tokens)?;
          28  +
                        /* JsonParserGenerator.kt:419 */
          29  +
                        let value =
          30  +
                            /* JsonParserGenerator.kt:544 */crate::protocol_serde::shape_replica::de_replica(tokens)?
          31  +
                        /* JsonParserGenerator.kt:419 */;
          32  +
                        /* JsonParserGenerator.kt:422 */
   20     33   
                        if let Some(value) = value {
   21     34   
                            items.push(value);
   22     35   
                        }
          36  +
                        /* JsonParserGenerator.kt:413 */
          37  +
                    } /* JsonParserGenerator.kt:409 */
   23     38   
                }
          39  +
                /* JsonParserGenerator.kt:408 */
   24     40   
            }
   25         -
            }
          41  +
            /* JsonParserGenerator.kt:446 */
   26     42   
            Ok(Some(items))
          43  +
            /* JsonParserGenerator.kt:713 */
   27     44   
        }
   28         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
          45  +
        /* JsonParserGenerator.kt:722 */
          46  +
        _ => {
          47  +
            /* JsonParserGenerator.kt:723 */
          48  +
            Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   29     49   
                "expected start array or null",
   30         -
        )),
          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_replica_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_replica_not_found_exception_json_err(
    3      4   
    value: &[u8],
    4      5   
    mut builder: crate::types::error::builders::ReplicaNotFoundErrorBuilder,
    5      6   
) -> ::std::result::Result<crate::types::error::builders::ReplicaNotFoundErrorBuilder, ::aws_smithy_json::deserialize::error::DeserializeError> {
           7  +
    /* JsonParserGenerator.kt:153 */
    6      8   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
    7      9   
    let tokens = &mut tokens_owned;
    8     10   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
          11  +
    /* JsonParserGenerator.kt:684 */
    9     12   
    loop {
          13  +
        /* JsonParserGenerator.kt:685 */
   10     14   
        match tokens.next().transpose()? {
   11         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   12         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
          15  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
          16  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
          17  +
                /* JsonParserGenerator.kt:260 */
          18  +
                match key.to_unescaped()?.as_ref() {
          19  +
                    /* JsonParserGenerator.kt:262 */
   13     20   
                    "message" => {
          21  +
                        /* JsonParserGenerator.kt:265 */
   14     22   
                        builder = builder.set_message(
          23  +
                            /* JsonParserGenerator.kt:354 */
   15     24   
                            ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   16         -
                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   17         -
                            .transpose()?,
          25  +
                                .map(|s|
          26  +
                                /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          27  +
                                    /* JsonParserGenerator.kt:348 */u.into_owned()
          28  +
                                /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
          29  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
   18     30   
                        );
          31  +
                        /* JsonParserGenerator.kt:262 */
   19     32   
                    }
   20         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   21         -
            },
          33  +
                    /* JsonParserGenerator.kt:290 */
          34  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
          35  +
                }
          36  +
                /* JsonParserGenerator.kt:686 */
          37  +
            }
          38  +
            /* JsonParserGenerator.kt:695 */
   22     39   
            other => {
   23     40   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   24     41   
                    "expected object key or end object, found: {:?}",
   25     42   
                    other
   26     43   
                )))
          44  +
            } /* JsonParserGenerator.kt:685 */
   27     45   
        }
          46  +
        /* JsonParserGenerator.kt:684 */
   28     47   
    }
   29         -
    }
          48  +
    /* JsonParserGenerator.kt:250 */
   30     49   
    if tokens.next().is_some() {
          50  +
        /* JsonParserGenerator.kt:251 */
   31     51   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   32     52   
            "found more JSON tokens after completing parsing",
   33     53   
        ));
          54  +
        /* JsonParserGenerator.kt:250 */
   34     55   
    }
          56  +
    /* JsonParserGenerator.kt:163 */
   35     57   
    Ok(builder)
          58  +
    /* JsonParserGenerator.kt:148 */
   36     59   
}

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

@@ -1,1 +85,140 @@
    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_replica_settings_description<'a, I>(
    3      4   
    tokens: &mut ::std::iter::Peekable<I>,
    4      5   
) -> ::std::result::Result<Option<crate::types::ReplicaSettingsDescription>, ::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::ReplicaSettingsDescriptionBuilder::default();
          17  +
            /* JsonParserGenerator.kt:684 */
   13     18   
            loop {
          19  +
                /* JsonParserGenerator.kt:685 */
   14     20   
                match tokens.next().transpose()? {
   15         -
                    Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   16         -
                    Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
          21  +
                    /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
          22  +
                    Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
          23  +
                        /* JsonParserGenerator.kt:260 */
          24  +
                        match key.to_unescaped()?.as_ref() {
          25  +
                            /* JsonParserGenerator.kt:262 */
   17     26   
                            "RegionName" => {
          27  +
                                /* JsonParserGenerator.kt:265 */
   18     28   
                                builder = builder.set_region_name(
          29  +
                                    /* JsonParserGenerator.kt:354 */
   19     30   
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   20         -
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   21         -
                                    .transpose()?,
          31  +
                                        .map(|s|
          32  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          33  +
                                            /* JsonParserGenerator.kt:348 */u.into_owned()
          34  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
          35  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
   22     36   
                                );
          37  +
                                /* JsonParserGenerator.kt:262 */
   23     38   
                            }
          39  +
                            /* JsonParserGenerator.kt:262 */
   24     40   
                            "ReplicaStatus" => {
          41  +
                                /* JsonParserGenerator.kt:265 */
   25     42   
                                builder = builder.set_replica_status(
          43  +
                                    /* JsonParserGenerator.kt:354 */
   26     44   
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   27         -
                                    .map(|s| s.to_unescaped().map(|u| crate::types::ReplicaStatus::from(u.as_ref())))
   28         -
                                    .transpose()?,
          45  +
                                        .map(|s|
          46  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          47  +
                                            /* JsonParserGenerator.kt:345 */crate::types::ReplicaStatus::from(u.as_ref())
          48  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
          49  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
   29     50   
                                );
          51  +
                                /* JsonParserGenerator.kt:262 */
   30     52   
                            }
          53  +
                            /* JsonParserGenerator.kt:262 */
   31     54   
                            "ReplicaBillingModeSummary" => {
          55  +
                                /* JsonParserGenerator.kt:265 */
   32     56   
                                builder = builder.set_replica_billing_mode_summary(
   33         -
                                crate::protocol_serde::shape_billing_mode_summary::de_billing_mode_summary(tokens)?,
   34         -
                            );
          57  +
                                    /* JsonParserGenerator.kt:544 */crate::protocol_serde::shape_billing_mode_summary::de_billing_mode_summary(tokens)?
          58  +
                                /* JsonParserGenerator.kt:265 */);
          59  +
                                /* JsonParserGenerator.kt:262 */
   35     60   
                            }
          61  +
                            /* JsonParserGenerator.kt:262 */
   36     62   
                            "ReplicaProvisionedReadCapacityUnits" => {
          63  +
                                /* JsonParserGenerator.kt:265 */
   37     64   
                                builder = builder.set_replica_provisioned_read_capacity_units(
          65  +
                                    /* JsonParserGenerator.kt:365 */
   38     66   
                                    ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
   39     67   
                                        .map(i64::try_from)
   40         -
                                    .transpose()?,
          68  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
   41     69   
                                );
          70  +
                                /* JsonParserGenerator.kt:262 */
   42     71   
                            }
          72  +
                            /* JsonParserGenerator.kt:262 */
   43     73   
                            "ReplicaProvisionedReadCapacityAutoScalingSettings" => {
          74  +
                                /* JsonParserGenerator.kt:265 */
   44     75   
                                builder = builder.set_replica_provisioned_read_capacity_auto_scaling_settings(
   45         -
                                crate::protocol_serde::shape_auto_scaling_settings_description::de_auto_scaling_settings_description(tokens)?,
   46         -
                            );
          76  +
                                    /* JsonParserGenerator.kt:544 */crate::protocol_serde::shape_auto_scaling_settings_description::de_auto_scaling_settings_description(tokens)?
          77  +
                                /* JsonParserGenerator.kt:265 */);
          78  +
                                /* JsonParserGenerator.kt:262 */
   47     79   
                            }
          80  +
                            /* JsonParserGenerator.kt:262 */
   48     81   
                            "ReplicaProvisionedWriteCapacityUnits" => {
          82  +
                                /* JsonParserGenerator.kt:265 */
   49     83   
                                builder = builder.set_replica_provisioned_write_capacity_units(
          84  +
                                    /* JsonParserGenerator.kt:365 */
   50     85   
                                    ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
   51     86   
                                        .map(i64::try_from)
   52         -
                                    .transpose()?,
          87  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
   53     88   
                                );
          89  +
                                /* JsonParserGenerator.kt:262 */
   54     90   
                            }
          91  +
                            /* JsonParserGenerator.kt:262 */
   55     92   
                            "ReplicaProvisionedWriteCapacityAutoScalingSettings" => {
          93  +
                                /* JsonParserGenerator.kt:265 */
   56     94   
                                builder = builder.set_replica_provisioned_write_capacity_auto_scaling_settings(
   57         -
                                crate::protocol_serde::shape_auto_scaling_settings_description::de_auto_scaling_settings_description(tokens)?,
   58         -
                            );
          95  +
                                    /* JsonParserGenerator.kt:544 */crate::protocol_serde::shape_auto_scaling_settings_description::de_auto_scaling_settings_description(tokens)?
          96  +
                                /* JsonParserGenerator.kt:265 */);
          97  +
                                /* JsonParserGenerator.kt:262 */
   59     98   
                            }
          99  +
                            /* JsonParserGenerator.kt:262 */
   60    100   
                            "ReplicaGlobalSecondaryIndexSettings" => {
         101  +
                                /* JsonParserGenerator.kt:265 */
   61    102   
                                builder = builder.set_replica_global_secondary_index_settings(
   62         -
                                    crate::protocol_serde::shape_replica_global_secondary_index_settings_description_list::de_replica_global_secondary_index_settings_description_list(tokens)?
   63         -
                                );
         103  +
                                    /* JsonParserGenerator.kt:451 */crate::protocol_serde::shape_replica_global_secondary_index_settings_description_list::de_replica_global_secondary_index_settings_description_list(tokens)?
         104  +
                                /* JsonParserGenerator.kt:265 */);
         105  +
                                /* JsonParserGenerator.kt:262 */
   64    106   
                            }
   65         -
                        _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   66         -
                    },
         107  +
                            /* JsonParserGenerator.kt:290 */
         108  +
                            _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
         109  +
                        }
         110  +
                        /* JsonParserGenerator.kt:686 */
         111  +
                    }
         112  +
                    /* JsonParserGenerator.kt:695 */
   67    113   
                    other => {
   68    114   
                        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   69    115   
                            "expected object key or end object, found: {:?}",
   70    116   
                            other
   71    117   
                        )))
         118  +
                    } /* JsonParserGenerator.kt:685 */
   72    119   
                }
         120  +
                /* JsonParserGenerator.kt:684 */
   73    121   
            }
   74         -
            }
         122  +
            /* JsonParserGenerator.kt:540 */
   75    123   
            Ok(Some(
   76    124   
                crate::serde_util::replica_settings_description_correct_errors(builder)
   77    125   
                    .build()
   78    126   
                    .map_err(|err| ::aws_smithy_json::deserialize::error::DeserializeError::custom_source("Response was invalid", err))?,
   79    127   
            ))
         128  +
            /* JsonParserGenerator.kt:713 */
   80    129   
        }
   81         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
         130  +
        /* JsonParserGenerator.kt:722 */
         131  +
        _ => {
         132  +
            /* JsonParserGenerator.kt:723 */
         133  +
            Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   82    134   
                "expected start object or null",
   83         -
        )),
         135  +
            ))
         136  +
            /* JsonParserGenerator.kt:722 */
         137  +
        } /* JsonParserGenerator.kt:712 */
   84    138   
    }
         139  +
    /* JsonParserGenerator.kt:516 */
   85    140   
}

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_replica_settings_description_list.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_replica_settings_description_list<'a, I>(
    3      4   
    tokens: &mut ::std::iter::Peekable<I>,
    4      5   
) -> ::std::result::Result<Option<::std::vec::Vec<crate::types::ReplicaSettingsDescription>>, ::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_replica_settings_description::de_replica_settings_description(tokens)?;
          28  +
                        /* JsonParserGenerator.kt:419 */
          29  +
                        let value =
          30  +
                            /* JsonParserGenerator.kt:544 */crate::protocol_serde::shape_replica_settings_description::de_replica_settings_description(tokens)?
          31  +
                        /* JsonParserGenerator.kt:419 */;
          32  +
                        /* JsonParserGenerator.kt:422 */
   20     33   
                        if let Some(value) = value {
   21     34   
                            items.push(value);
   22     35   
                        }
          36  +
                        /* JsonParserGenerator.kt:413 */
          37  +
                    } /* JsonParserGenerator.kt:409 */
   23     38   
                }
          39  +
                /* JsonParserGenerator.kt:408 */
   24     40   
            }
   25         -
            }
          41  +
            /* JsonParserGenerator.kt:446 */
   26     42   
            Ok(Some(items))
          43  +
            /* JsonParserGenerator.kt:713 */
   27     44   
        }
   28         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
          45  +
        /* JsonParserGenerator.kt:722 */
          46  +
        _ => {
          47  +
            /* JsonParserGenerator.kt:723 */
          48  +
            Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   29     49   
                "expected start array or null",
   30         -
        )),
          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_replica_settings_update.rs

@@ -1,1 +37,64 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_replica_settings_update(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::types::ReplicaSettingsUpdate,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* SerializerUtil.kt:42 */
    6      8   
    {
           9  +
        /* JsonSerializerGenerator.kt:423 */
    7     10   
        object.key("RegionName").string(input.region_name.as_str());
          11  +
        /* SerializerUtil.kt:42 */
    8     12   
    }
          13  +
    /* JsonSerializerGenerator.kt:382 */
    9     14   
    if let Some(var_1) = &input.replica_provisioned_read_capacity_units {
          15  +
        /* JsonSerializerGenerator.kt:432 */
   10     16   
        object.key("ReplicaProvisionedReadCapacityUnits").number(
   11     17   
            #[allow(clippy::useless_conversion)]
   12     18   
            ::aws_smithy_types::Number::NegInt((*var_1).into()),
   13     19   
        );
          20  +
        /* JsonSerializerGenerator.kt:382 */
   14     21   
    }
          22  +
    /* JsonSerializerGenerator.kt:382 */
   15     23   
    if let Some(var_2) = &input.replica_provisioned_read_capacity_auto_scaling_settings_update {
          24  +
        /* JsonSerializerGenerator.kt:495 */
   16     25   
        #[allow(unused_mut)]
          26  +
        /* JsonSerializerGenerator.kt:496 */
   17     27   
        let mut object_3 = object.key("ReplicaProvisionedReadCapacityAutoScalingSettingsUpdate").start_object();
          28  +
        /* JsonSerializerGenerator.kt:375 */
   18     29   
        crate::protocol_serde::shape_auto_scaling_settings_update::ser_auto_scaling_settings_update(&mut object_3, var_2)?;
          30  +
        /* JsonSerializerGenerator.kt:515 */
   19     31   
        object_3.finish();
          32  +
        /* JsonSerializerGenerator.kt:382 */
   20     33   
    }
          34  +
    /* JsonSerializerGenerator.kt:382 */
   21     35   
    if let Some(var_4) = &input.replica_global_secondary_index_settings_update {
          36  +
        /* JsonSerializerGenerator.kt:484 */
   22     37   
        let mut array_5 = object.key("ReplicaGlobalSecondaryIndexSettingsUpdate").start_array();
          38  +
        /* JsonSerializerGenerator.kt:524 */
   23     39   
        for item_6 in var_4 {
          40  +
            /* SerializerUtil.kt:42 */
   24     41   
            {
          42  +
                /* JsonSerializerGenerator.kt:495 */
   25     43   
                #[allow(unused_mut)]
          44  +
                /* JsonSerializerGenerator.kt:496 */
   26     45   
                let mut object_7 = array_5.value().start_object();
          46  +
                /* JsonSerializerGenerator.kt:375 */
   27     47   
                crate::protocol_serde::shape_replica_global_secondary_index_settings_update::ser_replica_global_secondary_index_settings_update(
   28     48   
                    &mut object_7,
   29     49   
                    item_6,
   30     50   
                )?;
          51  +
                /* JsonSerializerGenerator.kt:515 */
   31     52   
                object_7.finish();
          53  +
                /* SerializerUtil.kt:42 */
   32     54   
            }
          55  +
            /* JsonSerializerGenerator.kt:524 */
   33     56   
        }
          57  +
        /* JsonSerializerGenerator.kt:486 */
   34     58   
        array_5.finish();
          59  +
        /* JsonSerializerGenerator.kt:382 */
   35     60   
    }
          61  +
    /* JsonSerializerGenerator.kt:372 */
   36     62   
    Ok(())
          63  +
    /* JsonSerializerGenerator.kt:358 */
   37     64   
}

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

@@ -1,1 +19,34 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_replica_update(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::types::ReplicaUpdate,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.create {
           9  +
        /* JsonSerializerGenerator.kt:495 */
    7     10   
        #[allow(unused_mut)]
          11  +
        /* JsonSerializerGenerator.kt:496 */
    8     12   
        let mut object_2 = object.key("Create").start_object();
          13  +
        /* JsonSerializerGenerator.kt:375 */
    9     14   
        crate::protocol_serde::shape_create_replica_action::ser_create_replica_action(&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.delete {
          21  +
        /* JsonSerializerGenerator.kt:495 */
   13     22   
        #[allow(unused_mut)]
          23  +
        /* JsonSerializerGenerator.kt:496 */
   14     24   
        let mut object_4 = object.key("Delete").start_object();
          25  +
        /* JsonSerializerGenerator.kt:375 */
   15     26   
        crate::protocol_serde::shape_delete_replica_action::ser_delete_replica_action(&mut object_4, var_3)?;
          27  +
        /* JsonSerializerGenerator.kt:515 */
   16     28   
        object_4.finish();
          29  +
        /* JsonSerializerGenerator.kt:382 */
   17     30   
    }
          31  +
    /* JsonSerializerGenerator.kt:372 */
   18     32   
    Ok(())
          33  +
    /* JsonSerializerGenerator.kt:358 */
   19     34   
}

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

@@ -1,1 +25,46 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_replication_group_update(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::types::ReplicationGroupUpdate,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.create {
           9  +
        /* JsonSerializerGenerator.kt:495 */
    7     10   
        #[allow(unused_mut)]
          11  +
        /* JsonSerializerGenerator.kt:496 */
    8     12   
        let mut object_2 = object.key("Create").start_object();
          13  +
        /* JsonSerializerGenerator.kt:375 */
    9     14   
        crate::protocol_serde::shape_create_replication_group_member_action::ser_create_replication_group_member_action(&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.update {
          21  +
        /* JsonSerializerGenerator.kt:495 */
   13     22   
        #[allow(unused_mut)]
          23  +
        /* JsonSerializerGenerator.kt:496 */
   14     24   
        let mut object_4 = object.key("Update").start_object();
          25  +
        /* JsonSerializerGenerator.kt:375 */
   15     26   
        crate::protocol_serde::shape_update_replication_group_member_action::ser_update_replication_group_member_action(&mut object_4, var_3)?;
          27  +
        /* JsonSerializerGenerator.kt:515 */
   16     28   
        object_4.finish();
          29  +
        /* JsonSerializerGenerator.kt:382 */
   17     30   
    }
          31  +
    /* JsonSerializerGenerator.kt:382 */
   18     32   
    if let Some(var_5) = &input.delete {
          33  +
        /* JsonSerializerGenerator.kt:495 */
   19     34   
        #[allow(unused_mut)]
          35  +
        /* JsonSerializerGenerator.kt:496 */
   20     36   
        let mut object_6 = object.key("Delete").start_object();
          37  +
        /* JsonSerializerGenerator.kt:375 */
   21     38   
        crate::protocol_serde::shape_delete_replication_group_member_action::ser_delete_replication_group_member_action(&mut object_6, var_5)?;
          39  +
        /* JsonSerializerGenerator.kt:515 */
   22     40   
        object_6.finish();
          41  +
        /* JsonSerializerGenerator.kt:382 */
   23     42   
    }
          43  +
    /* JsonSerializerGenerator.kt:372 */
   24     44   
    Ok(())
          45  +
    /* JsonSerializerGenerator.kt:358 */
   25     46   
}

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

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

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

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

@@ -1,1 +58,105 @@
    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_restore_summary<'a, I>(
    3      4   
    tokens: &mut ::std::iter::Peekable<I>,
    4      5   
) -> ::std::result::Result<Option<crate::types::RestoreSummary>, ::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::RestoreSummaryBuilder::default();
          17  +
            /* JsonParserGenerator.kt:684 */
   13     18   
            loop {
          19  +
                /* JsonParserGenerator.kt:685 */
   14     20   
                match tokens.next().transpose()? {
   15         -
                    Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   16         -
                    Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
          21  +
                    /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
          22  +
                    Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
          23  +
                        /* JsonParserGenerator.kt:260 */
          24  +
                        match key.to_unescaped()?.as_ref() {
          25  +
                            /* JsonParserGenerator.kt:262 */
   17     26   
                            "SourceBackupArn" => {
          27  +
                                /* JsonParserGenerator.kt:265 */
   18     28   
                                builder = builder.set_source_backup_arn(
          29  +
                                    /* JsonParserGenerator.kt:354 */
   19     30   
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   20         -
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   21         -
                                    .transpose()?,
          31  +
                                        .map(|s|
          32  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          33  +
                                            /* JsonParserGenerator.kt:348 */u.into_owned()
          34  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
          35  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
   22     36   
                                );
          37  +
                                /* JsonParserGenerator.kt:262 */
   23     38   
                            }
          39  +
                            /* JsonParserGenerator.kt:262 */
   24     40   
                            "SourceTableArn" => {
          41  +
                                /* JsonParserGenerator.kt:265 */
   25     42   
                                builder = builder.set_source_table_arn(
          43  +
                                    /* JsonParserGenerator.kt:354 */
   26     44   
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   27         -
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   28         -
                                    .transpose()?,
          45  +
                                        .map(|s|
          46  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          47  +
                                            /* JsonParserGenerator.kt:348 */u.into_owned()
          48  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
          49  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
   29     50   
                                );
          51  +
                                /* JsonParserGenerator.kt:262 */
   30     52   
                            }
          53  +
                            /* JsonParserGenerator.kt:262 */
   31     54   
                            "RestoreDateTime" => {
   32         -
                            builder = builder.set_restore_date_time(::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
          55  +
                                /* JsonParserGenerator.kt:265 */
          56  +
                                builder = builder.set_restore_date_time(
          57  +
                                    /* JsonParserGenerator.kt:384 */
          58  +
                                    ::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
   33     59   
                                        tokens.next(),
   34     60   
                                        ::aws_smithy_types::date_time::Format::EpochSeconds,
   35         -
                            )?);
          61  +
                                    )?, /* JsonParserGenerator.kt:265 */
          62  +
                                );
          63  +
                                /* JsonParserGenerator.kt:262 */
   36     64   
                            }
          65  +
                            /* JsonParserGenerator.kt:262 */
   37     66   
                            "RestoreInProgress" => {
   38         -
                            builder = builder.set_restore_in_progress(::aws_smithy_json::deserialize::token::expect_bool_or_null(tokens.next())?);
          67  +
                                /* JsonParserGenerator.kt:265 */
          68  +
                                builder = builder.set_restore_in_progress(
          69  +
                                    /* JsonParserGenerator.kt:298 */
          70  +
                                    ::aws_smithy_json::deserialize::token::expect_bool_or_null(tokens.next())?, /* JsonParserGenerator.kt:265 */
          71  +
                                );
          72  +
                                /* JsonParserGenerator.kt:262 */
          73  +
                            }
          74  +
                            /* JsonParserGenerator.kt:290 */
          75  +
                            _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
   39     76   
                        }
   40         -
                        _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   41         -
                    },
          77  +
                        /* JsonParserGenerator.kt:686 */
          78  +
                    }
          79  +
                    /* JsonParserGenerator.kt:695 */
   42     80   
                    other => {
   43     81   
                        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   44     82   
                            "expected object key or end object, found: {:?}",
   45     83   
                            other
   46     84   
                        )))
          85  +
                    } /* JsonParserGenerator.kt:685 */
   47     86   
                }
          87  +
                /* JsonParserGenerator.kt:684 */
   48     88   
            }
   49         -
            }
          89  +
            /* JsonParserGenerator.kt:540 */
   50     90   
            Ok(Some(crate::serde_util::restore_summary_correct_errors(builder).build().map_err(
   51     91   
                |err| ::aws_smithy_json::deserialize::error::DeserializeError::custom_source("Response was invalid", err),
   52     92   
            )?))
          93  +
            /* JsonParserGenerator.kt:713 */
   53     94   
        }
   54         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
          95  +
        /* JsonParserGenerator.kt:722 */
          96  +
        _ => {
          97  +
            /* JsonParserGenerator.kt:723 */
          98  +
            Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   55     99   
                "expected start object or null",
   56         -
        )),
         100  +
            ))
         101  +
            /* JsonParserGenerator.kt:722 */
         102  +
        } /* JsonParserGenerator.kt:712 */
   57    103   
    }
         104  +
    /* JsonParserGenerator.kt:516 */
   58    105   
}

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

@@ -1,1 +197,285 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* RustType.kt:516 */
    2      3   
#[allow(clippy::unnecessary_wraps)]
           4  +
/* ProtocolParserGenerator.kt:99 */
    3      5   
pub fn de_restore_table_from_backup_http_error(
    4      6   
    _response_status: u16,
    5      7   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
    6      8   
    _response_body: &[u8],
    7      9   
) -> std::result::Result<
    8     10   
    crate::operation::restore_table_from_backup::RestoreTableFromBackupOutput,
    9     11   
    crate::operation::restore_table_from_backup::RestoreTableFromBackupError,
   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::restore_table_from_backup::RestoreTableFromBackupError::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::restore_table_from_backup::RestoreTableFromBackupError::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   
        "BackupInUseException" => crate::operation::restore_table_from_backup::RestoreTableFromBackupError::BackupInUseError({
          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::BackupInUseErrorBuilder::default();
   31         -
                output = crate::protocol_serde::shape_backup_in_use_exception::de_backup_in_use_exception_json_err(_response_body, output)
   32         -
                    .map_err(crate::operation::restore_table_from_backup::RestoreTableFromBackupError::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::BackupInUseErrorBuilder::default();
          41  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_backup_in_use_exception::de_backup_in_use_exception_json_err(_response_body, output).map_err(crate::operation::restore_table_from_backup::RestoreTableFromBackupError::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   
        "BackupNotFoundException" => crate::operation::restore_table_from_backup::RestoreTableFromBackupError::BackupNotFoundError({
          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::BackupNotFoundErrorBuilder::default();
   46         -
                output = crate::protocol_serde::shape_backup_not_found_exception::de_backup_not_found_exception_json_err(_response_body, output)
   47         -
                    .map_err(crate::operation::restore_table_from_backup::RestoreTableFromBackupError::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::BackupNotFoundErrorBuilder::default();
          62  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_backup_not_found_exception::de_backup_not_found_exception_json_err(_response_body, output).map_err(crate::operation::restore_table_from_backup::RestoreTableFromBackupError::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   
        "InternalServerError" => crate::operation::restore_table_from_backup::RestoreTableFromBackupError::InternalServerError({
          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::InternalServerErrorBuilder::default();
   61         -
                output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output)
   62         -
                    .map_err(crate::operation::restore_table_from_backup::RestoreTableFromBackupError::unhandled)?;
   63         -
                let output = output.meta(generic);
   64         -
                output.build()
   65         -
            };
          79  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          80  +
                /* ProtocolParserGenerator.kt:146 */ {
          81  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          82  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::InternalServerErrorBuilder::default();
          83  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output).map_err(crate::operation::restore_table_from_backup::RestoreTableFromBackupError::unhandled)?;
          84  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          85  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
          86  +
                /* ProtocolParserGenerator.kt:146 */}
          87  +
            /* ProtocolParserGenerator.kt:145 */;
          88  +
            /* ProtocolParserGenerator.kt:170 */
   66     89   
            if tmp.message.is_none() {
   67     90   
                tmp.message = _error_message;
   68     91   
            }
          92  +
            /* ProtocolParserGenerator.kt:179 */
   69     93   
            tmp
          94  +
            /* ProtocolParserGenerator.kt:139 */
   70     95   
        }),
          96  +
        /* ProtocolParserGenerator.kt:139 */
   71     97   
        "InvalidEndpointException" => crate::operation::restore_table_from_backup::RestoreTableFromBackupError::InvalidEndpointError({
          98  +
            /* RustType.kt:516 */
   72     99   
            #[allow(unused_mut)]
   73         -
            let mut tmp = {
   74         -
                #[allow(unused_mut)]
   75         -
                let mut output = crate::types::error::builders::InvalidEndpointErrorBuilder::default();
   76         -
                output = crate::protocol_serde::shape_invalid_endpoint_exception::de_invalid_endpoint_exception_json_err(_response_body, output)
   77         -
                    .map_err(crate::operation::restore_table_from_backup::RestoreTableFromBackupError::unhandled)?;
   78         -
                let output = output.meta(generic);
   79         -
                output.build()
   80         -
            };
         100  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
         101  +
                /* ProtocolParserGenerator.kt:146 */ {
         102  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
         103  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::InvalidEndpointErrorBuilder::default();
         104  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_invalid_endpoint_exception::de_invalid_endpoint_exception_json_err(_response_body, output).map_err(crate::operation::restore_table_from_backup::RestoreTableFromBackupError::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 */
   81    110   
            if tmp.message.is_none() {
   82    111   
                tmp.message = _error_message;
   83    112   
            }
         113  +
            /* ProtocolParserGenerator.kt:179 */
   84    114   
            tmp
         115  +
            /* ProtocolParserGenerator.kt:139 */
   85    116   
        }),
         117  +
        /* ProtocolParserGenerator.kt:139 */
   86    118   
        "LimitExceededException" => crate::operation::restore_table_from_backup::RestoreTableFromBackupError::LimitExceededError({
         119  +
            /* RustType.kt:516 */
   87    120   
            #[allow(unused_mut)]
   88         -
            let mut tmp = {
   89         -
                #[allow(unused_mut)]
   90         -
                let mut output = crate::types::error::builders::LimitExceededErrorBuilder::default();
   91         -
                output = crate::protocol_serde::shape_limit_exceeded_exception::de_limit_exceeded_exception_json_err(_response_body, output)
   92         -
                    .map_err(crate::operation::restore_table_from_backup::RestoreTableFromBackupError::unhandled)?;
   93         -
                let output = output.meta(generic);
   94         -
                output.build()
   95         -
            };
         121  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
         122  +
                /* ProtocolParserGenerator.kt:146 */ {
         123  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
         124  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::LimitExceededErrorBuilder::default();
         125  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_limit_exceeded_exception::de_limit_exceeded_exception_json_err(_response_body, output).map_err(crate::operation::restore_table_from_backup::RestoreTableFromBackupError::unhandled)?;
         126  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
         127  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
         128  +
                /* ProtocolParserGenerator.kt:146 */}
         129  +
            /* ProtocolParserGenerator.kt:145 */;
         130  +
            /* ProtocolParserGenerator.kt:170 */
   96    131   
            if tmp.message.is_none() {
   97    132   
                tmp.message = _error_message;
   98    133   
            }
         134  +
            /* ProtocolParserGenerator.kt:179 */
   99    135   
            tmp
         136  +
            /* ProtocolParserGenerator.kt:139 */
  100    137   
        }),
         138  +
        /* ProtocolParserGenerator.kt:139 */
  101    139   
        "TableAlreadyExistsException" => crate::operation::restore_table_from_backup::RestoreTableFromBackupError::TableAlreadyExistsError({
         140  +
            /* RustType.kt:516 */
  102    141   
            #[allow(unused_mut)]
  103         -
            let mut tmp = {
  104         -
                #[allow(unused_mut)]
  105         -
                let mut output = crate::types::error::builders::TableAlreadyExistsErrorBuilder::default();
  106         -
                output =
  107         -
                    crate::protocol_serde::shape_table_already_exists_exception::de_table_already_exists_exception_json_err(_response_body, output)
  108         -
                        .map_err(crate::operation::restore_table_from_backup::RestoreTableFromBackupError::unhandled)?;
  109         -
                let output = output.meta(generic);
  110         -
                output.build()
  111         -
            };
         142  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
         143  +
                /* ProtocolParserGenerator.kt:146 */ {
         144  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
         145  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::TableAlreadyExistsErrorBuilder::default();
         146  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_table_already_exists_exception::de_table_already_exists_exception_json_err(_response_body, output).map_err(crate::operation::restore_table_from_backup::RestoreTableFromBackupError::unhandled)?;
         147  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
         148  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
         149  +
                /* ProtocolParserGenerator.kt:146 */}
         150  +
            /* ProtocolParserGenerator.kt:145 */;
         151  +
            /* ProtocolParserGenerator.kt:170 */
  112    152   
            if tmp.message.is_none() {
  113    153   
                tmp.message = _error_message;
  114    154   
            }
         155  +
            /* ProtocolParserGenerator.kt:179 */
  115    156   
            tmp
         157  +
            /* ProtocolParserGenerator.kt:139 */
  116    158   
        }),
         159  +
        /* ProtocolParserGenerator.kt:139 */
  117    160   
        "TableInUseException" => crate::operation::restore_table_from_backup::RestoreTableFromBackupError::TableInUseError({
         161  +
            /* RustType.kt:516 */
  118    162   
            #[allow(unused_mut)]
  119         -
            let mut tmp = {
  120         -
                #[allow(unused_mut)]
  121         -
                let mut output = crate::types::error::builders::TableInUseErrorBuilder::default();
  122         -
                output = crate::protocol_serde::shape_table_in_use_exception::de_table_in_use_exception_json_err(_response_body, output)
  123         -
                    .map_err(crate::operation::restore_table_from_backup::RestoreTableFromBackupError::unhandled)?;
  124         -
                let output = output.meta(generic);
  125         -
                output.build()
  126         -
            };
         163  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
         164  +
                /* ProtocolParserGenerator.kt:146 */ {
         165  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
         166  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::TableInUseErrorBuilder::default();
         167  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_table_in_use_exception::de_table_in_use_exception_json_err(_response_body, output).map_err(crate::operation::restore_table_from_backup::RestoreTableFromBackupError::unhandled)?;
         168  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
         169  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
         170  +
                /* ProtocolParserGenerator.kt:146 */}
         171  +
            /* ProtocolParserGenerator.kt:145 */;
         172  +
            /* ProtocolParserGenerator.kt:170 */
  127    173   
            if tmp.message.is_none() {
  128    174   
                tmp.message = _error_message;
  129    175   
            }
         176  +
            /* ProtocolParserGenerator.kt:179 */
  130    177   
            tmp
         178  +
            /* ProtocolParserGenerator.kt:139 */
  131    179   
        }),
  132         -
        _ => crate::operation::restore_table_from_backup::RestoreTableFromBackupError::generic(generic),
         180  +
        /* ProtocolParserGenerator.kt:182 */
         181  +
        _ => crate::operation::restore_table_from_backup::RestoreTableFromBackupError::generic(generic), /* ProtocolParserGenerator.kt:133 */
  133    182   
    })
         183  +
    /* ProtocolParserGenerator.kt:99 */
  134    184   
}
  135    185   
         186  +
/* RustType.kt:516 */
  136    187   
#[allow(clippy::unnecessary_wraps)]
         188  +
/* ProtocolParserGenerator.kt:71 */
  137    189   
pub fn de_restore_table_from_backup_http_response(
  138    190   
    _response_status: u16,
  139    191   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
  140    192   
    _response_body: &[u8],
  141    193   
) -> std::result::Result<
  142    194   
    crate::operation::restore_table_from_backup::RestoreTableFromBackupOutput,
  143    195   
    crate::operation::restore_table_from_backup::RestoreTableFromBackupError,
  144    196   
> {
         197  +
    /* ProtocolParserGenerator.kt:77 */
  145    198   
    Ok({
         199  +
        /* RustType.kt:516 */
  146    200   
        #[allow(unused_mut)]
         201  +
        /* ProtocolParserGenerator.kt:240 */
  147    202   
        let mut output = crate::operation::restore_table_from_backup::builders::RestoreTableFromBackupOutputBuilder::default();
         203  +
        /* ProtocolParserGenerator.kt:247 */
  148    204   
        output = crate::protocol_serde::shape_restore_table_from_backup::de_restore_table_from_backup(_response_body, output)
  149    205   
            .map_err(crate::operation::restore_table_from_backup::RestoreTableFromBackupError::unhandled)?;
         206  +
        /* ClientBuilderInstantiator.kt:56 */
  150    207   
        output.build()
         208  +
        /* ProtocolParserGenerator.kt:77 */
  151    209   
    })
         210  +
    /* ProtocolParserGenerator.kt:71 */
  152    211   
}
  153    212   
         213  +
/* JsonSerializerGenerator.kt:287 */
  154    214   
pub fn ser_restore_table_from_backup_input(
  155    215   
    input: &crate::operation::restore_table_from_backup::RestoreTableFromBackupInput,
  156    216   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
         217  +
    /* JsonSerializerGenerator.kt:291 */
  157    218   
    let mut out = String::new();
         219  +
    /* JsonSerializerGenerator.kt:292 */
  158    220   
    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
         221  +
    /* JsonSerializerGenerator.kt:375 */
  159    222   
    crate::protocol_serde::shape_restore_table_from_backup_input::ser_restore_table_from_backup_input_input(&mut object, input)?;
         223  +
    /* JsonSerializerGenerator.kt:295 */
  160    224   
    object.finish();
         225  +
    /* JsonSerializerGenerator.kt:296 */
  161    226   
    Ok(::aws_smithy_types::body::SdkBody::from(out))
         227  +
    /* JsonSerializerGenerator.kt:287 */
  162    228   
}
  163    229   
         230  +
/* JsonParserGenerator.kt:148 */
  164    231   
pub(crate) fn de_restore_table_from_backup(
  165    232   
    value: &[u8],
  166    233   
    mut builder: crate::operation::restore_table_from_backup::builders::RestoreTableFromBackupOutputBuilder,
  167    234   
) -> ::std::result::Result<
  168    235   
    crate::operation::restore_table_from_backup::builders::RestoreTableFromBackupOutputBuilder,
  169    236   
    ::aws_smithy_json::deserialize::error::DeserializeError,
  170    237   
> {
         238  +
    /* JsonParserGenerator.kt:153 */
  171    239   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
  172    240   
    let tokens = &mut tokens_owned;
  173    241   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
         242  +
    /* JsonParserGenerator.kt:684 */
  174    243   
    loop {
         244  +
        /* JsonParserGenerator.kt:685 */
  175    245   
        match tokens.next().transpose()? {
  176         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
  177         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
         246  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
         247  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
         248  +
                /* JsonParserGenerator.kt:260 */
         249  +
                match key.to_unescaped()?.as_ref() {
         250  +
                    /* JsonParserGenerator.kt:262 */
  178    251   
                    "TableDescription" => {
  179         -
                    builder = builder.set_table_description(crate::protocol_serde::shape_table_description::de_table_description(tokens)?);
         252  +
                        /* JsonParserGenerator.kt:265 */
         253  +
                        builder = builder.set_table_description(
         254  +
                            /* JsonParserGenerator.kt:544 */
         255  +
                            crate::protocol_serde::shape_table_description::de_table_description(tokens)?, /* JsonParserGenerator.kt:265 */
         256  +
                        );
         257  +
                        /* JsonParserGenerator.kt:262 */
  180    258   
                    }
  181         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
  182         -
            },
         259  +
                    /* JsonParserGenerator.kt:290 */
         260  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
         261  +
                }
         262  +
                /* JsonParserGenerator.kt:686 */
         263  +
            }
         264  +
            /* JsonParserGenerator.kt:695 */
  183    265   
            other => {
  184    266   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
  185    267   
                    "expected object key or end object, found: {:?}",
  186    268   
                    other
  187    269   
                )))
         270  +
            } /* JsonParserGenerator.kt:685 */
  188    271   
        }
         272  +
        /* JsonParserGenerator.kt:684 */
  189    273   
    }
  190         -
    }
         274  +
    /* JsonParserGenerator.kt:250 */
  191    275   
    if tokens.next().is_some() {
         276  +
        /* JsonParserGenerator.kt:251 */
  192    277   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
  193    278   
            "found more JSON tokens after completing parsing",
  194    279   
        ));
         280  +
        /* JsonParserGenerator.kt:250 */
  195    281   
    }
         282  +
    /* JsonParserGenerator.kt:163 */
  196    283   
    Ok(builder)
         284  +
    /* JsonParserGenerator.kt:148 */
  197    285   
}

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

@@ -1,1 +52,100 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_restore_table_from_backup_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::restore_table_from_backup::RestoreTableFromBackupInput,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.target_table_name {
           9  +
        /* JsonSerializerGenerator.kt:423 */
    7     10   
        object.key("TargetTableName").string(var_1.as_str());
          11  +
        /* JsonSerializerGenerator.kt:382 */
    8     12   
    }
          13  +
    /* JsonSerializerGenerator.kt:382 */
    9     14   
    if let Some(var_2) = &input.backup_arn {
          15  +
        /* JsonSerializerGenerator.kt:423 */
   10     16   
        object.key("BackupArn").string(var_2.as_str());
          17  +
        /* JsonSerializerGenerator.kt:382 */
   11     18   
    }
          19  +
    /* JsonSerializerGenerator.kt:382 */
   12     20   
    if let Some(var_3) = &input.billing_mode_override {
          21  +
        /* JsonSerializerGenerator.kt:423 */
   13     22   
        object.key("BillingModeOverride").string(var_3.as_str());
          23  +
        /* JsonSerializerGenerator.kt:382 */
   14     24   
    }
          25  +
    /* JsonSerializerGenerator.kt:382 */
   15     26   
    if let Some(var_4) = &input.global_secondary_index_override {
          27  +
        /* JsonSerializerGenerator.kt:484 */
   16     28   
        let mut array_5 = object.key("GlobalSecondaryIndexOverride").start_array();
          29  +
        /* JsonSerializerGenerator.kt:524 */
   17     30   
        for item_6 in var_4 {
          31  +
            /* SerializerUtil.kt:42 */
   18     32   
            {
          33  +
                /* JsonSerializerGenerator.kt:495 */
   19     34   
                #[allow(unused_mut)]
          35  +
                /* JsonSerializerGenerator.kt:496 */
   20     36   
                let mut object_7 = array_5.value().start_object();
          37  +
                /* JsonSerializerGenerator.kt:375 */
   21     38   
                crate::protocol_serde::shape_global_secondary_index::ser_global_secondary_index(&mut object_7, item_6)?;
          39  +
                /* JsonSerializerGenerator.kt:515 */
   22     40   
                object_7.finish();
          41  +
                /* SerializerUtil.kt:42 */
   23     42   
            }
          43  +
            /* JsonSerializerGenerator.kt:524 */
   24     44   
        }
          45  +
        /* JsonSerializerGenerator.kt:486 */
   25     46   
        array_5.finish();
          47  +
        /* JsonSerializerGenerator.kt:382 */
   26     48   
    }
          49  +
    /* JsonSerializerGenerator.kt:382 */
   27     50   
    if let Some(var_8) = &input.local_secondary_index_override {
          51  +
        /* JsonSerializerGenerator.kt:484 */
   28     52   
        let mut array_9 = object.key("LocalSecondaryIndexOverride").start_array();
          53  +
        /* JsonSerializerGenerator.kt:524 */
   29     54   
        for item_10 in var_8 {
          55  +
            /* SerializerUtil.kt:42 */
   30     56   
            {
          57  +
                /* JsonSerializerGenerator.kt:495 */
   31     58   
                #[allow(unused_mut)]
          59  +
                /* JsonSerializerGenerator.kt:496 */
   32     60   
                let mut object_11 = array_9.value().start_object();
          61  +
                /* JsonSerializerGenerator.kt:375 */
   33     62   
                crate::protocol_serde::shape_local_secondary_index::ser_local_secondary_index(&mut object_11, item_10)?;
          63  +
                /* JsonSerializerGenerator.kt:515 */
   34     64   
                object_11.finish();
          65  +
                /* SerializerUtil.kt:42 */
   35     66   
            }
          67  +
            /* JsonSerializerGenerator.kt:524 */
   36     68   
        }
          69  +
        /* JsonSerializerGenerator.kt:486 */
   37     70   
        array_9.finish();
          71  +
        /* JsonSerializerGenerator.kt:382 */
   38     72   
    }
          73  +
    /* JsonSerializerGenerator.kt:382 */
   39     74   
    if let Some(var_12) = &input.provisioned_throughput_override {
          75  +
        /* JsonSerializerGenerator.kt:495 */
   40     76   
        #[allow(unused_mut)]
          77  +
        /* JsonSerializerGenerator.kt:496 */
   41     78   
        let mut object_13 = object.key("ProvisionedThroughputOverride").start_object();
          79  +
        /* JsonSerializerGenerator.kt:375 */
   42     80   
        crate::protocol_serde::shape_provisioned_throughput::ser_provisioned_throughput(&mut object_13, var_12)?;
          81  +
        /* JsonSerializerGenerator.kt:515 */
   43     82   
        object_13.finish();
          83  +
        /* JsonSerializerGenerator.kt:382 */
   44     84   
    }
          85  +
    /* JsonSerializerGenerator.kt:382 */
   45     86   
    if let Some(var_14) = &input.sse_specification_override {
          87  +
        /* JsonSerializerGenerator.kt:495 */
   46     88   
        #[allow(unused_mut)]
          89  +
        /* JsonSerializerGenerator.kt:496 */
   47     90   
        let mut object_15 = object.key("SSESpecificationOverride").start_object();
          91  +
        /* JsonSerializerGenerator.kt:375 */
   48     92   
        crate::protocol_serde::shape_sse_specification::ser_sse_specification(&mut object_15, var_14)?;
          93  +
        /* JsonSerializerGenerator.kt:515 */
   49     94   
        object_15.finish();
          95  +
        /* JsonSerializerGenerator.kt:382 */
   50     96   
    }
          97  +
    /* JsonSerializerGenerator.kt:372 */
   51     98   
    Ok(())
          99  +
    /* JsonSerializerGenerator.kt:358 */
   52    100   
}

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

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

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

@@ -1,1 +63,120 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_restore_table_to_point_in_time_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::restore_table_to_point_in_time::RestoreTableToPointInTimeInput,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.source_table_arn {
           9  +
        /* JsonSerializerGenerator.kt:423 */
    7     10   
        object.key("SourceTableArn").string(var_1.as_str());
          11  +
        /* JsonSerializerGenerator.kt:382 */
    8     12   
    }
          13  +
    /* JsonSerializerGenerator.kt:382 */
    9     14   
    if let Some(var_2) = &input.source_table_name {
          15  +
        /* JsonSerializerGenerator.kt:423 */
   10     16   
        object.key("SourceTableName").string(var_2.as_str());
          17  +
        /* JsonSerializerGenerator.kt:382 */
   11     18   
    }
          19  +
    /* JsonSerializerGenerator.kt:382 */
   12     20   
    if let Some(var_3) = &input.target_table_name {
          21  +
        /* JsonSerializerGenerator.kt:423 */
   13     22   
        object.key("TargetTableName").string(var_3.as_str());
          23  +
        /* JsonSerializerGenerator.kt:382 */
   14     24   
    }
          25  +
    /* JsonSerializerGenerator.kt:382 */
   15     26   
    if let Some(var_4) = &input.use_latest_restorable_time {
          27  +
        /* JsonSerializerGenerator.kt:424 */
   16     28   
        object.key("UseLatestRestorableTime").boolean(*var_4);
          29  +
        /* JsonSerializerGenerator.kt:382 */
   17     30   
    }
          31  +
    /* JsonSerializerGenerator.kt:382 */
   18     32   
    if let Some(var_5) = &input.restore_date_time {
          33  +
        /* JsonSerializerGenerator.kt:448 */
   19     34   
        object
   20     35   
            .key("RestoreDateTime")
   21     36   
            .date_time(var_5, ::aws_smithy_types::date_time::Format::EpochSeconds)?;
          37  +
        /* JsonSerializerGenerator.kt:382 */
   22     38   
    }
          39  +
    /* JsonSerializerGenerator.kt:382 */
   23     40   
    if let Some(var_6) = &input.billing_mode_override {
          41  +
        /* JsonSerializerGenerator.kt:423 */
   24     42   
        object.key("BillingModeOverride").string(var_6.as_str());
          43  +
        /* JsonSerializerGenerator.kt:382 */
   25     44   
    }
          45  +
    /* JsonSerializerGenerator.kt:382 */
   26     46   
    if let Some(var_7) = &input.global_secondary_index_override {
          47  +
        /* JsonSerializerGenerator.kt:484 */
   27     48   
        let mut array_8 = object.key("GlobalSecondaryIndexOverride").start_array();
          49  +
        /* JsonSerializerGenerator.kt:524 */
   28     50   
        for item_9 in var_7 {
          51  +
            /* SerializerUtil.kt:42 */
   29     52   
            {
          53  +
                /* JsonSerializerGenerator.kt:495 */
   30     54   
                #[allow(unused_mut)]
          55  +
                /* JsonSerializerGenerator.kt:496 */
   31     56   
                let mut object_10 = array_8.value().start_object();
          57  +
                /* JsonSerializerGenerator.kt:375 */
   32     58   
                crate::protocol_serde::shape_global_secondary_index::ser_global_secondary_index(&mut object_10, item_9)?;
          59  +
                /* JsonSerializerGenerator.kt:515 */
   33     60   
                object_10.finish();
          61  +
                /* SerializerUtil.kt:42 */
   34     62   
            }
          63  +
            /* JsonSerializerGenerator.kt:524 */
   35     64   
        }
          65  +
        /* JsonSerializerGenerator.kt:486 */
   36     66   
        array_8.finish();
          67  +
        /* JsonSerializerGenerator.kt:382 */
   37     68   
    }
          69  +
    /* JsonSerializerGenerator.kt:382 */
   38     70   
    if let Some(var_11) = &input.local_secondary_index_override {
          71  +
        /* JsonSerializerGenerator.kt:484 */
   39     72   
        let mut array_12 = object.key("LocalSecondaryIndexOverride").start_array();
          73  +
        /* JsonSerializerGenerator.kt:524 */
   40     74   
        for item_13 in var_11 {
          75  +
            /* SerializerUtil.kt:42 */
   41     76   
            {
          77  +
                /* JsonSerializerGenerator.kt:495 */
   42     78   
                #[allow(unused_mut)]
          79  +
                /* JsonSerializerGenerator.kt:496 */
   43     80   
                let mut object_14 = array_12.value().start_object();
          81  +
                /* JsonSerializerGenerator.kt:375 */
   44     82   
                crate::protocol_serde::shape_local_secondary_index::ser_local_secondary_index(&mut object_14, item_13)?;
          83  +
                /* JsonSerializerGenerator.kt:515 */
   45     84   
                object_14.finish();
          85  +
                /* SerializerUtil.kt:42 */
   46     86   
            }
          87  +
            /* JsonSerializerGenerator.kt:524 */
   47     88   
        }
          89  +
        /* JsonSerializerGenerator.kt:486 */
   48     90   
        array_12.finish();
          91  +
        /* JsonSerializerGenerator.kt:382 */
   49     92   
    }
          93  +
    /* JsonSerializerGenerator.kt:382 */
   50     94   
    if let Some(var_15) = &input.provisioned_throughput_override {
          95  +
        /* JsonSerializerGenerator.kt:495 */
   51     96   
        #[allow(unused_mut)]
          97  +
        /* JsonSerializerGenerator.kt:496 */
   52     98   
        let mut object_16 = object.key("ProvisionedThroughputOverride").start_object();
          99  +
        /* JsonSerializerGenerator.kt:375 */
   53    100   
        crate::protocol_serde::shape_provisioned_throughput::ser_provisioned_throughput(&mut object_16, var_15)?;
         101  +
        /* JsonSerializerGenerator.kt:515 */
   54    102   
        object_16.finish();
         103  +
        /* JsonSerializerGenerator.kt:382 */
   55    104   
    }
         105  +
    /* JsonSerializerGenerator.kt:382 */
   56    106   
    if let Some(var_17) = &input.sse_specification_override {
         107  +
        /* JsonSerializerGenerator.kt:495 */
   57    108   
        #[allow(unused_mut)]
         109  +
        /* JsonSerializerGenerator.kt:496 */
   58    110   
        let mut object_18 = object.key("SSESpecificationOverride").start_object();
         111  +
        /* JsonSerializerGenerator.kt:375 */
   59    112   
        crate::protocol_serde::shape_sse_specification::ser_sse_specification(&mut object_18, var_17)?;
         113  +
        /* JsonSerializerGenerator.kt:515 */
   60    114   
        object_18.finish();
         115  +
        /* JsonSerializerGenerator.kt:382 */
   61    116   
    }
         117  +
    /* JsonSerializerGenerator.kt:372 */
   62    118   
    Ok(())
         119  +
    /* JsonSerializerGenerator.kt:358 */
   63    120   
}