Client Test

Client Test

rev. dfb5149b65b7bcc09edd15b8e071ad43b5ac5943 (ignoring whitespace)

Files changed:

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

@@ -1,1 +16,28 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_attribute_value_update(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::types::AttributeValueUpdate,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.value {
           9  +
        /* JsonSerializerGenerator.kt:495 */
    7     10   
        #[allow(unused_mut)]
          11  +
        /* JsonSerializerGenerator.kt:496 */
    8     12   
        let mut object_2 = object.key("Value").start_object();
          13  +
        /* JsonSerializerGenerator.kt:579 */
    9     14   
        crate::protocol_serde::shape_attribute_value::ser_attribute_value(&mut object_2, var_1)?;
          15  +
        /* JsonSerializerGenerator.kt:515 */
   10     16   
        object_2.finish();
          17  +
        /* JsonSerializerGenerator.kt:382 */
   11     18   
    }
          19  +
    /* JsonSerializerGenerator.kt:382 */
   12     20   
    if let Some(var_3) = &input.action {
          21  +
        /* JsonSerializerGenerator.kt:423 */
   13     22   
        object.key("Action").string(var_3.as_str());
          23  +
        /* JsonSerializerGenerator.kt:382 */
   14     24   
    }
          25  +
    /* JsonSerializerGenerator.kt:372 */
   15     26   
    Ok(())
          27  +
    /* JsonSerializerGenerator.kt:358 */
   16     28   
}

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

@@ -1,1 +45,76 @@
    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_auto_scaling_policy_description<'a, I>(
    3      4   
    tokens: &mut ::std::iter::Peekable<I>,
    4      5   
) -> ::std::result::Result<Option<crate::types::AutoScalingPolicyDescription>, ::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::AutoScalingPolicyDescriptionBuilder::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   
                            "PolicyName" => {
          27  +
                                /* JsonParserGenerator.kt:265 */
   18     28   
                                builder = builder.set_policy_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   
                            "TargetTrackingScalingPolicyConfiguration" => {
          41  +
                                /* JsonParserGenerator.kt:265 */
   25     42   
                                builder = builder.set_target_tracking_scaling_policy_configuration(
   26         -
                                    crate::protocol_serde::shape_auto_scaling_target_tracking_scaling_policy_configuration_description::de_auto_scaling_target_tracking_scaling_policy_configuration_description(tokens)?
   27         -
                                );
          43  +
                                    /* JsonParserGenerator.kt:544 */crate::protocol_serde::shape_auto_scaling_target_tracking_scaling_policy_configuration_description::de_auto_scaling_target_tracking_scaling_policy_configuration_description(tokens)?
          44  +
                                /* JsonParserGenerator.kt:265 */);
          45  +
                                /* JsonParserGenerator.kt:262 */
          46  +
                            }
          47  +
                            /* JsonParserGenerator.kt:290 */
          48  +
                            _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
   28     49   
                        }
   29         -
                        _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   30         -
                    },
          50  +
                        /* JsonParserGenerator.kt:686 */
          51  +
                    }
          52  +
                    /* JsonParserGenerator.kt:695 */
   31     53   
                    other => {
   32     54   
                        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   33     55   
                            "expected object key or end object, found: {:?}",
   34     56   
                            other
   35     57   
                        )))
          58  +
                    } /* JsonParserGenerator.kt:685 */
   36     59   
                }
          60  +
                /* JsonParserGenerator.kt:684 */
   37     61   
            }
   38         -
            }
          62  +
            /* JsonParserGenerator.kt:540 */
   39     63   
            Ok(Some(builder.build()))
          64  +
            /* JsonParserGenerator.kt:713 */
   40     65   
        }
   41         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
          66  +
        /* JsonParserGenerator.kt:722 */
          67  +
        _ => {
          68  +
            /* JsonParserGenerator.kt:723 */
          69  +
            Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   42     70   
                "expected start object or null",
   43         -
        )),
          71  +
            ))
          72  +
            /* JsonParserGenerator.kt:722 */
          73  +
        } /* JsonParserGenerator.kt:712 */
   44     74   
    }
          75  +
    /* JsonParserGenerator.kt:516 */
   45     76   
}

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_auto_scaling_policy_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_auto_scaling_policy_description_list<'a, I>(
    3      4   
    tokens: &mut ::std::iter::Peekable<I>,
    4      5   
) -> ::std::result::Result<Option<::std::vec::Vec<crate::types::AutoScalingPolicyDescription>>, ::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_auto_scaling_policy_description::de_auto_scaling_policy_description(tokens)?;
          28  +
                        /* JsonParserGenerator.kt:419 */
          29  +
                        let value =
          30  +
                            /* JsonParserGenerator.kt:544 */crate::protocol_serde::shape_auto_scaling_policy_description::de_auto_scaling_policy_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_auto_scaling_policy_update.rs

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

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

@@ -1,1 +62,110 @@
    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_auto_scaling_settings_description<'a, I>(
    3      4   
    tokens: &mut ::std::iter::Peekable<I>,
    4      5   
) -> ::std::result::Result<Option<crate::types::AutoScalingSettingsDescription>, ::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::AutoScalingSettingsDescriptionBuilder::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   
                            "MinimumUnits" => {
          27  +
                                /* JsonParserGenerator.kt:265 */
   18     28   
                                builder = builder.set_minimum_units(
          29  +
                                    /* JsonParserGenerator.kt:365 */
   19     30   
                                    ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
   20     31   
                                        .map(i64::try_from)
   21         -
                                    .transpose()?,
          32  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
   22     33   
                                );
          34  +
                                /* JsonParserGenerator.kt:262 */
   23     35   
                            }
          36  +
                            /* JsonParserGenerator.kt:262 */
   24     37   
                            "MaximumUnits" => {
          38  +
                                /* JsonParserGenerator.kt:265 */
   25     39   
                                builder = builder.set_maximum_units(
          40  +
                                    /* JsonParserGenerator.kt:365 */
   26     41   
                                    ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
   27     42   
                                        .map(i64::try_from)
   28         -
                                    .transpose()?,
          43  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
   29     44   
                                );
          45  +
                                /* JsonParserGenerator.kt:262 */
   30     46   
                            }
          47  +
                            /* JsonParserGenerator.kt:262 */
   31     48   
                            "AutoScalingDisabled" => {
   32         -
                            builder = builder.set_auto_scaling_disabled(::aws_smithy_json::deserialize::token::expect_bool_or_null(tokens.next())?);
          49  +
                                /* JsonParserGenerator.kt:265 */
          50  +
                                builder = builder.set_auto_scaling_disabled(
          51  +
                                    /* JsonParserGenerator.kt:298 */
          52  +
                                    ::aws_smithy_json::deserialize::token::expect_bool_or_null(tokens.next())?, /* JsonParserGenerator.kt:265 */
          53  +
                                );
          54  +
                                /* JsonParserGenerator.kt:262 */
   33     55   
                            }
          56  +
                            /* JsonParserGenerator.kt:262 */
   34     57   
                            "AutoScalingRoleArn" => {
          58  +
                                /* JsonParserGenerator.kt:265 */
   35     59   
                                builder = builder.set_auto_scaling_role_arn(
          60  +
                                    /* JsonParserGenerator.kt:354 */
   36     61   
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   37         -
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   38         -
                                    .transpose()?,
          62  +
                                        .map(|s|
          63  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          64  +
                                            /* JsonParserGenerator.kt:348 */u.into_owned()
          65  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
          66  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
   39     67   
                                );
          68  +
                                /* JsonParserGenerator.kt:262 */
   40     69   
                            }
          70  +
                            /* JsonParserGenerator.kt:262 */
   41     71   
                            "ScalingPolicies" => {
          72  +
                                /* JsonParserGenerator.kt:265 */
   42     73   
                                builder = builder.set_scaling_policies(
   43         -
                                crate::protocol_serde::shape_auto_scaling_policy_description_list::de_auto_scaling_policy_description_list(tokens)?,
          74  +
                                    /* JsonParserGenerator.kt:451 */
          75  +
                                    crate::protocol_serde::shape_auto_scaling_policy_description_list::de_auto_scaling_policy_description_list(
          76  +
                                        tokens,
          77  +
                                    )?, /* JsonParserGenerator.kt:265 */
   44     78   
                                );
          79  +
                                /* JsonParserGenerator.kt:262 */
          80  +
                            }
          81  +
                            /* JsonParserGenerator.kt:290 */
          82  +
                            _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
   45     83   
                        }
   46         -
                        _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   47         -
                    },
          84  +
                        /* JsonParserGenerator.kt:686 */
          85  +
                    }
          86  +
                    /* JsonParserGenerator.kt:695 */
   48     87   
                    other => {
   49     88   
                        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   50     89   
                            "expected object key or end object, found: {:?}",
   51     90   
                            other
   52     91   
                        )))
          92  +
                    } /* JsonParserGenerator.kt:685 */
   53     93   
                }
          94  +
                /* JsonParserGenerator.kt:684 */
   54     95   
            }
   55         -
            }
          96  +
            /* JsonParserGenerator.kt:540 */
   56     97   
            Ok(Some(builder.build()))
          98  +
            /* JsonParserGenerator.kt:713 */
   57     99   
        }
   58         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
         100  +
        /* JsonParserGenerator.kt:722 */
         101  +
        _ => {
         102  +
            /* JsonParserGenerator.kt:723 */
         103  +
            Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   59    104   
                "expected start object or null",
   60         -
        )),
         105  +
            ))
         106  +
            /* JsonParserGenerator.kt:722 */
         107  +
        } /* JsonParserGenerator.kt:712 */
   61    108   
    }
         109  +
    /* JsonParserGenerator.kt:516 */
   62    110   
}

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

@@ -1,1 +31,52 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_auto_scaling_settings_update(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::types::AutoScalingSettingsUpdate,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.minimum_units {
           9  +
        /* JsonSerializerGenerator.kt:432 */
    7     10   
        object.key("MinimumUnits").number(
    8     11   
            #[allow(clippy::useless_conversion)]
    9     12   
            ::aws_smithy_types::Number::NegInt((*var_1).into()),
   10     13   
        );
          14  +
        /* JsonSerializerGenerator.kt:382 */
   11     15   
    }
          16  +
    /* JsonSerializerGenerator.kt:382 */
   12     17   
    if let Some(var_2) = &input.maximum_units {
          18  +
        /* JsonSerializerGenerator.kt:432 */
   13     19   
        object.key("MaximumUnits").number(
   14     20   
            #[allow(clippy::useless_conversion)]
   15     21   
            ::aws_smithy_types::Number::NegInt((*var_2).into()),
   16     22   
        );
          23  +
        /* JsonSerializerGenerator.kt:382 */
   17     24   
    }
          25  +
    /* JsonSerializerGenerator.kt:382 */
   18     26   
    if let Some(var_3) = &input.auto_scaling_disabled {
          27  +
        /* JsonSerializerGenerator.kt:424 */
   19     28   
        object.key("AutoScalingDisabled").boolean(*var_3);
          29  +
        /* JsonSerializerGenerator.kt:382 */
   20     30   
    }
          31  +
    /* JsonSerializerGenerator.kt:382 */
   21     32   
    if let Some(var_4) = &input.auto_scaling_role_arn {
          33  +
        /* JsonSerializerGenerator.kt:423 */
   22     34   
        object.key("AutoScalingRoleArn").string(var_4.as_str());
          35  +
        /* JsonSerializerGenerator.kt:382 */
   23     36   
    }
          37  +
    /* JsonSerializerGenerator.kt:382 */
   24     38   
    if let Some(var_5) = &input.scaling_policy_update {
          39  +
        /* JsonSerializerGenerator.kt:495 */
   25     40   
        #[allow(unused_mut)]
          41  +
        /* JsonSerializerGenerator.kt:496 */
   26     42   
        let mut object_6 = object.key("ScalingPolicyUpdate").start_object();
          43  +
        /* JsonSerializerGenerator.kt:375 */
   27     44   
        crate::protocol_serde::shape_auto_scaling_policy_update::ser_auto_scaling_policy_update(&mut object_6, var_5)?;
          45  +
        /* JsonSerializerGenerator.kt:515 */
   28     46   
        object_6.finish();
          47  +
        /* JsonSerializerGenerator.kt:382 */
   29     48   
    }
          49  +
    /* JsonSerializerGenerator.kt:372 */
   30     50   
    Ok(())
          51  +
    /* JsonSerializerGenerator.kt:358 */
   31     52   
}

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

@@ -1,1 +62,100 @@
    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_auto_scaling_target_tracking_scaling_policy_configuration_description<'a, I>(
    3      4   
    tokens: &mut ::std::iter::Peekable<I>,
    4      5   
) -> ::std::result::Result<
    5      6   
    Option<crate::types::AutoScalingTargetTrackingScalingPolicyConfigurationDescription>,
    6      7   
    ::aws_smithy_json::deserialize::error::DeserializeError,
    7      8   
>
    8      9   
where
    9     10   
    I: Iterator<Item = Result<::aws_smithy_json::deserialize::Token<'a>, ::aws_smithy_json::deserialize::error::DeserializeError>>,
   10     11   
{
          12  +
    /* JsonParserGenerator.kt:712 */
   11     13   
    match tokens.next().transpose()? {
   12         -
        Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
          14  +
        /* JsonParserGenerator.kt:713 */ Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
   13     15   
        Some(::aws_smithy_json::deserialize::Token::StartObject { .. }) => {
          16  +
            /* RustType.kt:516 */
   14     17   
            #[allow(unused_mut)]
          18  +
            /* JsonParserGenerator.kt:526 */
   15     19   
            let mut builder = crate::types::builders::AutoScalingTargetTrackingScalingPolicyConfigurationDescriptionBuilder::default();
          20  +
            /* JsonParserGenerator.kt:684 */
   16     21   
            loop {
          22  +
                /* JsonParserGenerator.kt:685 */
   17     23   
                match tokens.next().transpose()? {
   18         -
                    Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   19         -
                    Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
          24  +
                    /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
          25  +
                    Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
          26  +
                        /* JsonParserGenerator.kt:260 */
          27  +
                        match key.to_unescaped()?.as_ref() {
          28  +
                            /* JsonParserGenerator.kt:262 */
   20     29   
                            "DisableScaleIn" => {
   21         -
                            builder = builder.set_disable_scale_in(::aws_smithy_json::deserialize::token::expect_bool_or_null(tokens.next())?);
          30  +
                                /* JsonParserGenerator.kt:265 */
          31  +
                                builder = builder.set_disable_scale_in(
          32  +
                                    /* JsonParserGenerator.kt:298 */
          33  +
                                    ::aws_smithy_json::deserialize::token::expect_bool_or_null(tokens.next())?, /* JsonParserGenerator.kt:265 */
          34  +
                                );
          35  +
                                /* JsonParserGenerator.kt:262 */
   22     36   
                            }
          37  +
                            /* JsonParserGenerator.kt:262 */
   23     38   
                            "ScaleInCooldown" => {
          39  +
                                /* JsonParserGenerator.kt:265 */
   24     40   
                                builder = builder.set_scale_in_cooldown(
          41  +
                                    /* JsonParserGenerator.kt:365 */
   25     42   
                                    ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
   26     43   
                                        .map(i32::try_from)
   27         -
                                    .transpose()?,
          44  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
   28     45   
                                );
          46  +
                                /* JsonParserGenerator.kt:262 */
   29     47   
                            }
          48  +
                            /* JsonParserGenerator.kt:262 */
   30     49   
                            "ScaleOutCooldown" => {
          50  +
                                /* JsonParserGenerator.kt:265 */
   31     51   
                                builder = builder.set_scale_out_cooldown(
          52  +
                                    /* JsonParserGenerator.kt:365 */
   32     53   
                                    ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
   33     54   
                                        .map(i32::try_from)
   34         -
                                    .transpose()?,
          55  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
   35     56   
                                );
          57  +
                                /* JsonParserGenerator.kt:262 */
   36     58   
                            }
          59  +
                            /* JsonParserGenerator.kt:262 */
   37     60   
                            "TargetValue" => {
          61  +
                                /* JsonParserGenerator.kt:265 */
   38     62   
                                builder = builder.set_target_value(
   39         -
                                ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?.map(|v| v.to_f64_lossy()),
   40         -
                            );
          63  +
                                    /* JsonParserGenerator.kt:363 */::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?.map(|v| v.to_f64_lossy())
          64  +
                                /* JsonParserGenerator.kt:265 */);
          65  +
                                /* JsonParserGenerator.kt:262 */
          66  +
                            }
          67  +
                            /* JsonParserGenerator.kt:290 */
          68  +
                            _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
   41     69   
                        }
   42         -
                        _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   43         -
                    },
          70  +
                        /* JsonParserGenerator.kt:686 */
          71  +
                    }
          72  +
                    /* JsonParserGenerator.kt:695 */
   44     73   
                    other => {
   45     74   
                        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   46     75   
                            "expected object key or end object, found: {:?}",
   47     76   
                            other
   48     77   
                        )))
          78  +
                    } /* JsonParserGenerator.kt:685 */
   49     79   
                }
          80  +
                /* JsonParserGenerator.kt:684 */
   50     81   
            }
   51         -
            }
          82  +
            /* JsonParserGenerator.kt:540 */
   52     83   
            Ok(Some(
   53     84   
                crate::serde_util::auto_scaling_target_tracking_scaling_policy_configuration_description_correct_errors(builder)
   54     85   
                    .build()
   55     86   
                    .map_err(|err| ::aws_smithy_json::deserialize::error::DeserializeError::custom_source("Response was invalid", err))?,
   56     87   
            ))
          88  +
            /* JsonParserGenerator.kt:713 */
   57     89   
        }
   58         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
          90  +
        /* JsonParserGenerator.kt:722 */
          91  +
        _ => {
          92  +
            /* JsonParserGenerator.kt:723 */
          93  +
            Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   59     94   
                "expected start object or null",
   60         -
        )),
          95  +
            ))
          96  +
            /* JsonParserGenerator.kt:722 */
          97  +
        } /* JsonParserGenerator.kt:712 */
   61     98   
    }
          99  +
    /* JsonParserGenerator.kt:516 */
   62    100   
}

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

@@ -1,1 +28,43 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_auto_scaling_target_tracking_scaling_policy_configuration_update(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::types::AutoScalingTargetTrackingScalingPolicyConfigurationUpdate,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.disable_scale_in {
           9  +
        /* JsonSerializerGenerator.kt:424 */
    7     10   
        object.key("DisableScaleIn").boolean(*var_1);
          11  +
        /* JsonSerializerGenerator.kt:382 */
    8     12   
    }
          13  +
    /* JsonSerializerGenerator.kt:382 */
    9     14   
    if let Some(var_2) = &input.scale_in_cooldown {
          15  +
        /* JsonSerializerGenerator.kt:432 */
   10     16   
        object.key("ScaleInCooldown").number(
   11     17   
            #[allow(clippy::useless_conversion)]
   12     18   
            ::aws_smithy_types::Number::NegInt((*var_2).into()),
   13     19   
        );
          20  +
        /* JsonSerializerGenerator.kt:382 */
   14     21   
    }
          22  +
    /* JsonSerializerGenerator.kt:382 */
   15     23   
    if let Some(var_3) = &input.scale_out_cooldown {
          24  +
        /* JsonSerializerGenerator.kt:432 */
   16     25   
        object.key("ScaleOutCooldown").number(
   17     26   
            #[allow(clippy::useless_conversion)]
   18     27   
            ::aws_smithy_types::Number::NegInt((*var_3).into()),
   19     28   
        );
          29  +
        /* JsonSerializerGenerator.kt:382 */
   20     30   
    }
          31  +
    /* SerializerUtil.kt:42 */
   21     32   
    {
          33  +
        /* JsonSerializerGenerator.kt:432 */
   22     34   
        object.key("TargetValue").number(
   23     35   
            #[allow(clippy::useless_conversion)]
   24     36   
            ::aws_smithy_types::Number::Float((input.target_value).into()),
   25     37   
        );
          38  +
        /* SerializerUtil.kt:42 */
   26     39   
    }
          40  +
    /* JsonSerializerGenerator.kt:372 */
   27     41   
    Ok(())
          42  +
    /* JsonSerializerGenerator.kt:358 */
   28     43   
}

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

@@ -1,1 +45,79 @@
    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_backup_description<'a, I>(
    3      4   
    tokens: &mut ::std::iter::Peekable<I>,
    4      5   
) -> ::std::result::Result<Option<crate::types::BackupDescription>, ::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::BackupDescriptionBuilder::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   
                            "BackupDetails" => {
   18         -
                            builder = builder.set_backup_details(crate::protocol_serde::shape_backup_details::de_backup_details(tokens)?);
          27  +
                                /* JsonParserGenerator.kt:265 */
          28  +
                                builder = builder.set_backup_details(
          29  +
                                    /* JsonParserGenerator.kt:544 */
          30  +
                                    crate::protocol_serde::shape_backup_details::de_backup_details(tokens)?, /* JsonParserGenerator.kt:265 */
          31  +
                                );
          32  +
                                /* JsonParserGenerator.kt:262 */
   19     33   
                            }
          34  +
                            /* JsonParserGenerator.kt:262 */
   20     35   
                            "SourceTableDetails" => {
   21         -
                            builder =
   22         -
                                builder.set_source_table_details(crate::protocol_serde::shape_source_table_details::de_source_table_details(tokens)?);
          36  +
                                /* JsonParserGenerator.kt:265 */
          37  +
                                builder = builder.set_source_table_details(
          38  +
                                    /* JsonParserGenerator.kt:544 */crate::protocol_serde::shape_source_table_details::de_source_table_details(tokens)?
          39  +
                                /* JsonParserGenerator.kt:265 */);
          40  +
                                /* JsonParserGenerator.kt:262 */
   23     41   
                            }
          42  +
                            /* JsonParserGenerator.kt:262 */
   24     43   
                            "SourceTableFeatureDetails" => {
          44  +
                                /* JsonParserGenerator.kt:265 */
   25     45   
                                builder = builder.set_source_table_feature_details(
   26         -
                                crate::protocol_serde::shape_source_table_feature_details::de_source_table_feature_details(tokens)?,
   27         -
                            );
          46  +
                                    /* JsonParserGenerator.kt:544 */crate::protocol_serde::shape_source_table_feature_details::de_source_table_feature_details(tokens)?
          47  +
                                /* JsonParserGenerator.kt:265 */);
          48  +
                                /* JsonParserGenerator.kt:262 */
          49  +
                            }
          50  +
                            /* JsonParserGenerator.kt:290 */
          51  +
                            _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
   28     52   
                        }
   29         -
                        _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   30         -
                    },
          53  +
                        /* JsonParserGenerator.kt:686 */
          54  +
                    }
          55  +
                    /* JsonParserGenerator.kt:695 */
   31     56   
                    other => {
   32     57   
                        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   33     58   
                            "expected object key or end object, found: {:?}",
   34     59   
                            other
   35     60   
                        )))
          61  +
                    } /* JsonParserGenerator.kt:685 */
   36     62   
                }
          63  +
                /* JsonParserGenerator.kt:684 */
   37     64   
            }
   38         -
            }
          65  +
            /* JsonParserGenerator.kt:540 */
   39     66   
            Ok(Some(builder.build()))
          67  +
            /* JsonParserGenerator.kt:713 */
   40     68   
        }
   41         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
          69  +
        /* JsonParserGenerator.kt:722 */
          70  +
        _ => {
          71  +
            /* JsonParserGenerator.kt:723 */
          72  +
            Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   42     73   
                "expected start object or null",
   43         -
        )),
          74  +
            ))
          75  +
            /* JsonParserGenerator.kt:722 */
          76  +
        } /* JsonParserGenerator.kt:712 */
   44     77   
    }
          78  +
    /* JsonParserGenerator.kt:516 */
   45     79   
}

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

@@ -1,1 +82,147 @@
    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_backup_details<'a, I>(
    3      4   
    tokens: &mut ::std::iter::Peekable<I>,
    4      5   
) -> ::std::result::Result<Option<crate::types::BackupDetails>, ::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::BackupDetailsBuilder::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   
                            "BackupArn" => {
          27  +
                                /* JsonParserGenerator.kt:265 */
   18     28   
                                builder = builder.set_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   
                            "BackupName" => {
          41  +
                                /* JsonParserGenerator.kt:265 */
   25     42   
                                builder = builder.set_backup_name(
          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   
                            "BackupSizeBytes" => {
          55  +
                                /* JsonParserGenerator.kt:265 */
   32     56   
                                builder = builder.set_backup_size_bytes(
          57  +
                                    /* JsonParserGenerator.kt:365 */
   33     58   
                                    ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
   34     59   
                                        .map(i64::try_from)
   35         -
                                    .transpose()?,
          60  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
   36     61   
                                );
          62  +
                                /* JsonParserGenerator.kt:262 */
   37     63   
                            }
          64  +
                            /* JsonParserGenerator.kt:262 */
   38     65   
                            "BackupStatus" => {
          66  +
                                /* JsonParserGenerator.kt:265 */
   39     67   
                                builder = builder.set_backup_status(
          68  +
                                    /* JsonParserGenerator.kt:354 */
   40     69   
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   41         -
                                    .map(|s| s.to_unescaped().map(|u| crate::types::BackupStatus::from(u.as_ref())))
   42         -
                                    .transpose()?,
          70  +
                                        .map(|s|
          71  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          72  +
                                            /* JsonParserGenerator.kt:345 */crate::types::BackupStatus::from(u.as_ref())
          73  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
          74  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
   43     75   
                                );
          76  +
                                /* JsonParserGenerator.kt:262 */
   44     77   
                            }
          78  +
                            /* JsonParserGenerator.kt:262 */
   45     79   
                            "BackupType" => {
          80  +
                                /* JsonParserGenerator.kt:265 */
   46     81   
                                builder = builder.set_backup_type(
          82  +
                                    /* JsonParserGenerator.kt:354 */
   47     83   
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   48         -
                                    .map(|s| s.to_unescaped().map(|u| crate::types::BackupType::from(u.as_ref())))
   49         -
                                    .transpose()?,
          84  +
                                        .map(|s|
          85  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          86  +
                                            /* JsonParserGenerator.kt:345 */crate::types::BackupType::from(u.as_ref())
          87  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
          88  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
   50     89   
                                );
          90  +
                                /* JsonParserGenerator.kt:262 */
   51     91   
                            }
          92  +
                            /* JsonParserGenerator.kt:262 */
   52     93   
                            "BackupCreationDateTime" => {
   53         -
                            builder = builder.set_backup_creation_date_time(::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
          94  +
                                /* JsonParserGenerator.kt:265 */
          95  +
                                builder = builder.set_backup_creation_date_time(
          96  +
                                    /* JsonParserGenerator.kt:384 */
          97  +
                                    ::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
   54     98   
                                        tokens.next(),
   55     99   
                                        ::aws_smithy_types::date_time::Format::EpochSeconds,
   56         -
                            )?);
         100  +
                                    )?, /* JsonParserGenerator.kt:265 */
         101  +
                                );
         102  +
                                /* JsonParserGenerator.kt:262 */
   57    103   
                            }
         104  +
                            /* JsonParserGenerator.kt:262 */
   58    105   
                            "BackupExpiryDateTime" => {
   59         -
                            builder = builder.set_backup_expiry_date_time(::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
         106  +
                                /* JsonParserGenerator.kt:265 */
         107  +
                                builder = builder.set_backup_expiry_date_time(
         108  +
                                    /* JsonParserGenerator.kt:384 */
         109  +
                                    ::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
   60    110   
                                        tokens.next(),
   61    111   
                                        ::aws_smithy_types::date_time::Format::EpochSeconds,
   62         -
                            )?);
         112  +
                                    )?, /* JsonParserGenerator.kt:265 */
         113  +
                                );
         114  +
                                /* JsonParserGenerator.kt:262 */
         115  +
                            }
         116  +
                            /* JsonParserGenerator.kt:290 */
         117  +
                            _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
   63    118   
                        }
   64         -
                        _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   65         -
                    },
         119  +
                        /* JsonParserGenerator.kt:686 */
         120  +
                    }
         121  +
                    /* JsonParserGenerator.kt:695 */
   66    122   
                    other => {
   67    123   
                        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   68    124   
                            "expected object key or end object, found: {:?}",
   69    125   
                            other
   70    126   
                        )))
         127  +
                    } /* JsonParserGenerator.kt:685 */
   71    128   
                }
         129  +
                /* JsonParserGenerator.kt:684 */
   72    130   
            }
   73         -
            }
         131  +
            /* JsonParserGenerator.kt:540 */
   74    132   
            Ok(Some(crate::serde_util::backup_details_correct_errors(builder).build().map_err(
   75    133   
                |err| ::aws_smithy_json::deserialize::error::DeserializeError::custom_source("Response was invalid", err),
   76    134   
            )?))
         135  +
            /* JsonParserGenerator.kt:713 */
   77    136   
        }
   78         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
         137  +
        /* JsonParserGenerator.kt:722 */
         138  +
        _ => {
         139  +
            /* JsonParserGenerator.kt:723 */
         140  +
            Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   79    141   
                "expected start object or null",
   80         -
        )),
         142  +
            ))
         143  +
            /* JsonParserGenerator.kt:722 */
         144  +
        } /* JsonParserGenerator.kt:712 */
   81    145   
    }
         146  +
    /* JsonParserGenerator.kt:516 */
   82    147   
}

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_backup_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_backup_in_use_exception_json_err(
    3      4   
    value: &[u8],
    4      5   
    mut builder: crate::types::error::builders::BackupInUseErrorBuilder,
    5      6   
) -> ::std::result::Result<crate::types::error::builders::BackupInUseErrorBuilder, ::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_backup_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_backup_not_found_exception_json_err(
    3      4   
    value: &[u8],
    4      5   
    mut builder: crate::types::error::builders::BackupNotFoundErrorBuilder,
    5      6   
) -> ::std::result::Result<crate::types::error::builders::BackupNotFoundErrorBuilder, ::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_backup_summaries.rs

@@ -1,1 +32,55 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonParserGenerator.kt:398 */
    2      3   
pub(crate) fn de_backup_summaries<'a, I>(
    3      4   
    tokens: &mut ::std::iter::Peekable<I>,
    4      5   
) -> ::std::result::Result<Option<::std::vec::Vec<crate::types::BackupSummary>>, ::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_backup_summary::de_backup_summary(tokens)?;
          28  +
                        /* JsonParserGenerator.kt:419 */
          29  +
                        let value =
          30  +
                            /* JsonParserGenerator.kt:544 */crate::protocol_serde::shape_backup_summary::de_backup_summary(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_backup_summary.rs

@@ -1,1 +101,187 @@
    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_backup_summary<'a, I>(
    3      4   
    tokens: &mut ::std::iter::Peekable<I>,
    4      5   
) -> ::std::result::Result<Option<crate::types::BackupSummary>, ::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::BackupSummaryBuilder::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   
                            "TableName" => {
          27  +
                                /* JsonParserGenerator.kt:265 */
   18     28   
                                builder = builder.set_table_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   
                            "TableId" => {
          41  +
                                /* JsonParserGenerator.kt:265 */
   25     42   
                                builder = builder.set_table_id(
          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   
                            "TableArn" => {
          55  +
                                /* JsonParserGenerator.kt:265 */
   32     56   
                                builder = builder.set_table_arn(
          57  +
                                    /* JsonParserGenerator.kt:354 */
   33     58   
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   34         -
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   35         -
                                    .transpose()?,
          59  +
                                        .map(|s|
          60  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          61  +
                                            /* JsonParserGenerator.kt:348 */u.into_owned()
          62  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
          63  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
   36     64   
                                );
          65  +
                                /* JsonParserGenerator.kt:262 */
   37     66   
                            }
          67  +
                            /* JsonParserGenerator.kt:262 */
   38     68   
                            "BackupArn" => {
          69  +
                                /* JsonParserGenerator.kt:265 */
   39     70   
                                builder = builder.set_backup_arn(
          71  +
                                    /* JsonParserGenerator.kt:354 */
   40     72   
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   41         -
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   42         -
                                    .transpose()?,
          73  +
                                        .map(|s|
          74  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          75  +
                                            /* JsonParserGenerator.kt:348 */u.into_owned()
          76  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
          77  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
   43     78   
                                );
          79  +
                                /* JsonParserGenerator.kt:262 */
   44     80   
                            }
          81  +
                            /* JsonParserGenerator.kt:262 */
   45     82   
                            "BackupName" => {
          83  +
                                /* JsonParserGenerator.kt:265 */
   46     84   
                                builder = builder.set_backup_name(
          85  +
                                    /* JsonParserGenerator.kt:354 */
   47     86   
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   48         -
                                    .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   49         -
                                    .transpose()?,
          87  +
                                        .map(|s|
          88  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          89  +
                                            /* JsonParserGenerator.kt:348 */u.into_owned()
          90  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
          91  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
   50     92   
                                );
          93  +
                                /* JsonParserGenerator.kt:262 */
   51     94   
                            }
          95  +
                            /* JsonParserGenerator.kt:262 */
   52     96   
                            "BackupCreationDateTime" => {
   53         -
                            builder = builder.set_backup_creation_date_time(::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
          97  +
                                /* JsonParserGenerator.kt:265 */
          98  +
                                builder = builder.set_backup_creation_date_time(
          99  +
                                    /* JsonParserGenerator.kt:384 */
         100  +
                                    ::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
   54    101   
                                        tokens.next(),
   55    102   
                                        ::aws_smithy_types::date_time::Format::EpochSeconds,
   56         -
                            )?);
         103  +
                                    )?, /* JsonParserGenerator.kt:265 */
         104  +
                                );
         105  +
                                /* JsonParserGenerator.kt:262 */
   57    106   
                            }
         107  +
                            /* JsonParserGenerator.kt:262 */
   58    108   
                            "BackupExpiryDateTime" => {
   59         -
                            builder = builder.set_backup_expiry_date_time(::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
         109  +
                                /* JsonParserGenerator.kt:265 */
         110  +
                                builder = builder.set_backup_expiry_date_time(
         111  +
                                    /* JsonParserGenerator.kt:384 */
         112  +
                                    ::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
   60    113   
                                        tokens.next(),
   61    114   
                                        ::aws_smithy_types::date_time::Format::EpochSeconds,
   62         -
                            )?);
         115  +
                                    )?, /* JsonParserGenerator.kt:265 */
         116  +
                                );
         117  +
                                /* JsonParserGenerator.kt:262 */
   63    118   
                            }
         119  +
                            /* JsonParserGenerator.kt:262 */
   64    120   
                            "BackupStatus" => {
         121  +
                                /* JsonParserGenerator.kt:265 */
   65    122   
                                builder = builder.set_backup_status(
         123  +
                                    /* JsonParserGenerator.kt:354 */
   66    124   
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   67         -
                                    .map(|s| s.to_unescaped().map(|u| crate::types::BackupStatus::from(u.as_ref())))
   68         -
                                    .transpose()?,
         125  +
                                        .map(|s|
         126  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
         127  +
                                            /* JsonParserGenerator.kt:345 */crate::types::BackupStatus::from(u.as_ref())
         128  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
         129  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
   69    130   
                                );
         131  +
                                /* JsonParserGenerator.kt:262 */
   70    132   
                            }
         133  +
                            /* JsonParserGenerator.kt:262 */
   71    134   
                            "BackupType" => {
         135  +
                                /* JsonParserGenerator.kt:265 */
   72    136   
                                builder = builder.set_backup_type(
         137  +
                                    /* JsonParserGenerator.kt:354 */
   73    138   
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   74         -
                                    .map(|s| s.to_unescaped().map(|u| crate::types::BackupType::from(u.as_ref())))
   75         -
                                    .transpose()?,
         139  +
                                        .map(|s|
         140  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
         141  +
                                            /* JsonParserGenerator.kt:345 */crate::types::BackupType::from(u.as_ref())
         142  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
         143  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
   76    144   
                                );
         145  +
                                /* JsonParserGenerator.kt:262 */
   77    146   
                            }
         147  +
                            /* JsonParserGenerator.kt:262 */
   78    148   
                            "BackupSizeBytes" => {
         149  +
                                /* JsonParserGenerator.kt:265 */
   79    150   
                                builder = builder.set_backup_size_bytes(
         151  +
                                    /* JsonParserGenerator.kt:365 */
   80    152   
                                    ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
   81    153   
                                        .map(i64::try_from)
   82         -
                                    .transpose()?,
         154  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
   83    155   
                                );
         156  +
                                /* JsonParserGenerator.kt:262 */
         157  +
                            }
         158  +
                            /* JsonParserGenerator.kt:290 */
         159  +
                            _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
   84    160   
                        }
   85         -
                        _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   86         -
                    },
         161  +
                        /* JsonParserGenerator.kt:686 */
         162  +
                    }
         163  +
                    /* JsonParserGenerator.kt:695 */
   87    164   
                    other => {
   88    165   
                        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   89    166   
                            "expected object key or end object, found: {:?}",
   90    167   
                            other
   91    168   
                        )))
         169  +
                    } /* JsonParserGenerator.kt:685 */
   92    170   
                }
         171  +
                /* JsonParserGenerator.kt:684 */
   93    172   
            }
   94         -
            }
         173  +
            /* JsonParserGenerator.kt:540 */
   95    174   
            Ok(Some(builder.build()))
         175  +
            /* JsonParserGenerator.kt:713 */
   96    176   
        }
   97         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
         177  +
        /* JsonParserGenerator.kt:722 */
         178  +
        _ => {
         179  +
            /* JsonParserGenerator.kt:723 */
         180  +
            Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   98    181   
                "expected start object or null",
   99         -
        )),
         182  +
            ))
         183  +
            /* JsonParserGenerator.kt:722 */
         184  +
        } /* JsonParserGenerator.kt:712 */
  100    185   
    }
         186  +
    /* JsonParserGenerator.kt:516 */
  101    187   
}

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

@@ -1,1 +117,175 @@
    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_batch_execute_statement_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::batch_execute_statement::BatchExecuteStatementOutput,
    9     11   
    crate::operation::batch_execute_statement::BatchExecuteStatementError,
   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::batch_execute_statement::BatchExecuteStatementError::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::batch_execute_statement::BatchExecuteStatementError::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::batch_execute_statement::BatchExecuteStatementError::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::batch_execute_statement::BatchExecuteStatementError::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::batch_execute_statement::BatchExecuteStatementError::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   
        "RequestLimitExceeded" => crate::operation::batch_execute_statement::BatchExecuteStatementError::RequestLimitExceeded({
          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::RequestLimitExceededBuilder::default();
   42         -
                output = crate::protocol_serde::shape_request_limit_exceeded::de_request_limit_exceeded_json_err(_response_body, output)
   43         -
                    .map_err(crate::operation::batch_execute_statement::BatchExecuteStatementError::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::RequestLimitExceededBuilder::default();
          58  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_request_limit_exceeded::de_request_limit_exceeded_json_err(_response_body, output).map_err(crate::operation::batch_execute_statement::BatchExecuteStatementError::unhandled)?;
          59  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          60  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
          61  +
                /* ProtocolParserGenerator.kt:146 */}
          62  +
            /* ProtocolParserGenerator.kt:145 */;
          63  +
            /* ProtocolParserGenerator.kt:170 */
   47     64   
            if tmp.message.is_none() {
   48     65   
                tmp.message = _error_message;
   49     66   
            }
          67  +
            /* ProtocolParserGenerator.kt:179 */
   50     68   
            tmp
          69  +
            /* ProtocolParserGenerator.kt:139 */
   51     70   
        }),
   52         -
        _ => crate::operation::batch_execute_statement::BatchExecuteStatementError::generic(generic),
          71  +
        /* ProtocolParserGenerator.kt:182 */
          72  +
        _ => crate::operation::batch_execute_statement::BatchExecuteStatementError::generic(generic), /* ProtocolParserGenerator.kt:133 */
   53     73   
    })
          74  +
    /* ProtocolParserGenerator.kt:99 */
   54     75   
}
   55     76   
          77  +
/* RustType.kt:516 */
   56     78   
#[allow(clippy::unnecessary_wraps)]
          79  +
/* ProtocolParserGenerator.kt:71 */
   57     80   
pub fn de_batch_execute_statement_http_response(
   58     81   
    _response_status: u16,
   59     82   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
   60     83   
    _response_body: &[u8],
   61     84   
) -> std::result::Result<
   62     85   
    crate::operation::batch_execute_statement::BatchExecuteStatementOutput,
   63     86   
    crate::operation::batch_execute_statement::BatchExecuteStatementError,
   64     87   
> {
          88  +
    /* ProtocolParserGenerator.kt:77 */
   65     89   
    Ok({
          90  +
        /* RustType.kt:516 */
   66     91   
        #[allow(unused_mut)]
          92  +
        /* ProtocolParserGenerator.kt:240 */
   67     93   
        let mut output = crate::operation::batch_execute_statement::builders::BatchExecuteStatementOutputBuilder::default();
          94  +
        /* ProtocolParserGenerator.kt:247 */
   68     95   
        output = crate::protocol_serde::shape_batch_execute_statement::de_batch_execute_statement(_response_body, output)
   69     96   
            .map_err(crate::operation::batch_execute_statement::BatchExecuteStatementError::unhandled)?;
          97  +
        /* ClientBuilderInstantiator.kt:56 */
   70     98   
        output.build()
          99  +
        /* ProtocolParserGenerator.kt:77 */
   71    100   
    })
         101  +
    /* ProtocolParserGenerator.kt:71 */
   72    102   
}
   73    103   
         104  +
/* JsonSerializerGenerator.kt:287 */
   74    105   
pub fn ser_batch_execute_statement_input(
   75    106   
    input: &crate::operation::batch_execute_statement::BatchExecuteStatementInput,
   76    107   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
         108  +
    /* JsonSerializerGenerator.kt:291 */
   77    109   
    let mut out = String::new();
         110  +
    /* JsonSerializerGenerator.kt:292 */
   78    111   
    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
         112  +
    /* JsonSerializerGenerator.kt:375 */
   79    113   
    crate::protocol_serde::shape_batch_execute_statement_input::ser_batch_execute_statement_input_input(&mut object, input)?;
         114  +
    /* JsonSerializerGenerator.kt:295 */
   80    115   
    object.finish();
         116  +
    /* JsonSerializerGenerator.kt:296 */
   81    117   
    Ok(::aws_smithy_types::body::SdkBody::from(out))
         118  +
    /* JsonSerializerGenerator.kt:287 */
   82    119   
}
   83    120   
         121  +
/* JsonParserGenerator.kt:148 */
   84    122   
pub(crate) fn de_batch_execute_statement(
   85    123   
    value: &[u8],
   86    124   
    mut builder: crate::operation::batch_execute_statement::builders::BatchExecuteStatementOutputBuilder,
   87    125   
) -> ::std::result::Result<
   88    126   
    crate::operation::batch_execute_statement::builders::BatchExecuteStatementOutputBuilder,
   89    127   
    ::aws_smithy_json::deserialize::error::DeserializeError,
   90    128   
> {
         129  +
    /* JsonParserGenerator.kt:153 */
   91    130   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
   92    131   
    let tokens = &mut tokens_owned;
   93    132   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
         133  +
    /* JsonParserGenerator.kt:684 */
   94    134   
    loop {
         135  +
        /* JsonParserGenerator.kt:685 */
   95    136   
        match tokens.next().transpose()? {
   96         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   97         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
         137  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
         138  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
         139  +
                /* JsonParserGenerator.kt:260 */
         140  +
                match key.to_unescaped()?.as_ref() {
         141  +
                    /* JsonParserGenerator.kt:262 */
   98    142   
                    "Responses" => {
   99         -
                    builder = builder.set_responses(crate::protocol_serde::shape_parti_ql_batch_response::de_parti_ql_batch_response(tokens)?);
         143  +
                        /* JsonParserGenerator.kt:265 */
         144  +
                        builder = builder.set_responses(
         145  +
                            /* JsonParserGenerator.kt:451 */crate::protocol_serde::shape_parti_ql_batch_response::de_parti_ql_batch_response(tokens)?
         146  +
                        /* JsonParserGenerator.kt:265 */);
         147  +
                        /* JsonParserGenerator.kt:262 */
         148  +
                    }
         149  +
                    /* JsonParserGenerator.kt:290 */
         150  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
  100    151   
                }
  101         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
  102         -
            },
         152  +
                /* JsonParserGenerator.kt:686 */
         153  +
            }
         154  +
            /* JsonParserGenerator.kt:695 */
  103    155   
            other => {
  104    156   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
  105    157   
                    "expected object key or end object, found: {:?}",
  106    158   
                    other
  107    159   
                )))
         160  +
            } /* JsonParserGenerator.kt:685 */
  108    161   
        }
         162  +
        /* JsonParserGenerator.kt:684 */
  109    163   
    }
  110         -
    }
         164  +
    /* JsonParserGenerator.kt:250 */
  111    165   
    if tokens.next().is_some() {
         166  +
        /* JsonParserGenerator.kt:251 */
  112    167   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
  113    168   
            "found more JSON tokens after completing parsing",
  114    169   
        ));
         170  +
        /* JsonParserGenerator.kt:250 */
  115    171   
    }
         172  +
    /* JsonParserGenerator.kt:163 */
  116    173   
    Ok(builder)
         174  +
    /* JsonParserGenerator.kt:148 */
  117    175   
}

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

@@ -1,1 +19,34 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_batch_execute_statement_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::batch_execute_statement::BatchExecuteStatementInput,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.statements {
           9  +
        /* JsonSerializerGenerator.kt:484 */
    7     10   
        let mut array_2 = object.key("Statements").start_array();
          11  +
        /* JsonSerializerGenerator.kt:524 */
    8     12   
        for item_3 in var_1 {
          13  +
            /* SerializerUtil.kt:42 */
    9     14   
            {
          15  +
                /* JsonSerializerGenerator.kt:495 */
   10     16   
                #[allow(unused_mut)]
          17  +
                /* JsonSerializerGenerator.kt:496 */
   11     18   
                let mut object_4 = array_2.value().start_object();
          19  +
                /* JsonSerializerGenerator.kt:375 */
   12     20   
                crate::protocol_serde::shape_batch_statement_request::ser_batch_statement_request(&mut object_4, item_3)?;
          21  +
                /* JsonSerializerGenerator.kt:515 */
   13     22   
                object_4.finish();
          23  +
                /* SerializerUtil.kt:42 */
   14     24   
            }
          25  +
            /* JsonSerializerGenerator.kt:524 */
   15     26   
        }
          27  +
        /* JsonSerializerGenerator.kt:486 */
   16     28   
        array_2.finish();
          29  +
        /* JsonSerializerGenerator.kt:382 */
   17     30   
    }
          31  +
    /* JsonSerializerGenerator.kt:372 */
   18     32   
    Ok(())
          33  +
    /* JsonSerializerGenerator.kt:358 */
   19     34   
}