Client Test

Client Test

rev. dfb5149b65b7bcc09edd15b8e071ad43b5ac5943 (ignoring whitespace)

Files changed:

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

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

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

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

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

@@ -1,1 +68,117 @@
    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_consumed_capacity<'a, I>(
    3      4   
    tokens: &mut ::std::iter::Peekable<I>,
    4      5   
) -> ::std::result::Result<Option<crate::types::ConsumedCapacity>, ::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::ConsumedCapacityBuilder::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   
                            "CapacityUnits" => {
          41  +
                                /* JsonParserGenerator.kt:265 */
   25     42   
                                builder = builder.set_capacity_units(
   26         -
                                ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?.map(|v| v.to_f64_lossy()),
   27         -
                            );
          43  +
                                    /* JsonParserGenerator.kt:363 */::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?.map(|v| v.to_f64_lossy())
          44  +
                                /* JsonParserGenerator.kt:265 */);
          45  +
                                /* JsonParserGenerator.kt:262 */
   28     46   
                            }
          47  +
                            /* JsonParserGenerator.kt:262 */
   29     48   
                            "ReadCapacityUnits" => {
          49  +
                                /* JsonParserGenerator.kt:265 */
   30     50   
                                builder = builder.set_read_capacity_units(
   31         -
                                ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?.map(|v| v.to_f64_lossy()),
   32         -
                            );
          51  +
                                    /* JsonParserGenerator.kt:363 */::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?.map(|v| v.to_f64_lossy())
          52  +
                                /* JsonParserGenerator.kt:265 */);
          53  +
                                /* JsonParserGenerator.kt:262 */
   33     54   
                            }
          55  +
                            /* JsonParserGenerator.kt:262 */
   34     56   
                            "WriteCapacityUnits" => {
          57  +
                                /* JsonParserGenerator.kt:265 */
   35     58   
                                builder = builder.set_write_capacity_units(
   36         -
                                ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?.map(|v| v.to_f64_lossy()),
   37         -
                            );
          59  +
                                    /* JsonParserGenerator.kt:363 */::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?.map(|v| v.to_f64_lossy())
          60  +
                                /* JsonParserGenerator.kt:265 */);
          61  +
                                /* JsonParserGenerator.kt:262 */
   38     62   
                            }
          63  +
                            /* JsonParserGenerator.kt:262 */
   39     64   
                            "Table" => {
   40         -
                            builder = builder.set_table(crate::protocol_serde::shape_capacity::de_capacity(tokens)?);
          65  +
                                /* JsonParserGenerator.kt:265 */
          66  +
                                builder = builder.set_table(
          67  +
                                    /* JsonParserGenerator.kt:544 */
          68  +
                                    crate::protocol_serde::shape_capacity::de_capacity(tokens)?, /* JsonParserGenerator.kt:265 */
          69  +
                                );
          70  +
                                /* JsonParserGenerator.kt:262 */
   41     71   
                            }
          72  +
                            /* JsonParserGenerator.kt:262 */
   42     73   
                            "LocalSecondaryIndexes" => {
          74  +
                                /* JsonParserGenerator.kt:265 */
   43     75   
                                builder = builder.set_local_secondary_indexes(
   44         -
                                crate::protocol_serde::shape_secondary_indexes_capacity_map::de_secondary_indexes_capacity_map(tokens)?,
   45         -
                            );
          76  +
                                    /* JsonParserGenerator.kt:509 */crate::protocol_serde::shape_secondary_indexes_capacity_map::de_secondary_indexes_capacity_map(tokens)?
          77  +
                                /* JsonParserGenerator.kt:265 */);
          78  +
                                /* JsonParserGenerator.kt:262 */
   46     79   
                            }
          80  +
                            /* JsonParserGenerator.kt:262 */
   47     81   
                            "GlobalSecondaryIndexes" => {
          82  +
                                /* JsonParserGenerator.kt:265 */
   48     83   
                                builder = builder.set_global_secondary_indexes(
   49         -
                                crate::protocol_serde::shape_secondary_indexes_capacity_map::de_secondary_indexes_capacity_map(tokens)?,
   50         -
                            );
          84  +
                                    /* JsonParserGenerator.kt:509 */crate::protocol_serde::shape_secondary_indexes_capacity_map::de_secondary_indexes_capacity_map(tokens)?
          85  +
                                /* JsonParserGenerator.kt:265 */);
          86  +
                                /* JsonParserGenerator.kt:262 */
          87  +
                            }
          88  +
                            /* JsonParserGenerator.kt:290 */
          89  +
                            _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
   51     90   
                        }
   52         -
                        _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   53         -
                    },
          91  +
                        /* JsonParserGenerator.kt:686 */
          92  +
                    }
          93  +
                    /* JsonParserGenerator.kt:695 */
   54     94   
                    other => {
   55     95   
                        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   56     96   
                            "expected object key or end object, found: {:?}",
   57     97   
                            other
   58     98   
                        )))
          99  +
                    } /* JsonParserGenerator.kt:685 */
   59    100   
                }
         101  +
                /* JsonParserGenerator.kt:684 */
   60    102   
            }
   61         -
            }
         103  +
            /* JsonParserGenerator.kt:540 */
   62    104   
            Ok(Some(builder.build()))
         105  +
            /* JsonParserGenerator.kt:713 */
   63    106   
        }
   64         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
         107  +
        /* JsonParserGenerator.kt:722 */
         108  +
        _ => {
         109  +
            /* JsonParserGenerator.kt:723 */
         110  +
            Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   65    111   
                "expected start object or null",
   66         -
        )),
         112  +
            ))
         113  +
            /* JsonParserGenerator.kt:722 */
         114  +
        } /* JsonParserGenerator.kt:712 */
   67    115   
    }
         116  +
    /* JsonParserGenerator.kt:516 */
   68    117   
}

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_consumed_capacity_multiple.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_consumed_capacity_multiple<'a, I>(
    3      4   
    tokens: &mut ::std::iter::Peekable<I>,
    4      5   
) -> ::std::result::Result<Option<::std::vec::Vec<crate::types::ConsumedCapacity>>, ::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_consumed_capacity::de_consumed_capacity(tokens)?;
          28  +
                        /* JsonParserGenerator.kt:419 */
          29  +
                        let value =
          30  +
                            /* JsonParserGenerator.kt:544 */crate::protocol_serde::shape_consumed_capacity::de_consumed_capacity(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_continuous_backups_description.rs

@@ -1,1 +49,84 @@
    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_continuous_backups_description<'a, I>(
    3      4   
    tokens: &mut ::std::iter::Peekable<I>,
    4      5   
) -> ::std::result::Result<Option<crate::types::ContinuousBackupsDescription>, ::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::ContinuousBackupsDescriptionBuilder::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   
                            "ContinuousBackupsStatus" => {
          27  +
                                /* JsonParserGenerator.kt:265 */
   18     28   
                                builder = builder.set_continuous_backups_status(
          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| crate::types::ContinuousBackupsStatus::from(u.as_ref())))
   21         -
                                    .transpose()?,
          31  +
                                        .map(|s|
          32  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          33  +
                                            /* JsonParserGenerator.kt:345 */crate::types::ContinuousBackupsStatus::from(u.as_ref())
          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   
                            "PointInTimeRecoveryDescription" => {
   25         -
                            builder = builder.set_point_in_time_recovery_description(
   26         -
                                crate::protocol_serde::shape_point_in_time_recovery_description::de_point_in_time_recovery_description(tokens)?,
          41  +
                                /* JsonParserGenerator.kt:265 */
          42  +
                                builder =
          43  +
                                    builder.set_point_in_time_recovery_description(
          44  +
                                        /* JsonParserGenerator.kt:544 */
          45  +
                                        crate::protocol_serde::shape_point_in_time_recovery_description::de_point_in_time_recovery_description(
          46  +
                                            tokens,
          47  +
                                        )?, /* JsonParserGenerator.kt:265 */
   27     48   
                                    );
          49  +
                                /* JsonParserGenerator.kt:262 */
   28     50   
                            }
   29         -
                        _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   30         -
                    },
          51  +
                            /* JsonParserGenerator.kt:290 */
          52  +
                            _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
          53  +
                        }
          54  +
                        /* JsonParserGenerator.kt:686 */
          55  +
                    }
          56  +
                    /* JsonParserGenerator.kt:695 */
   31     57   
                    other => {
   32     58   
                        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   33     59   
                            "expected object key or end object, found: {:?}",
   34     60   
                            other
   35     61   
                        )))
          62  +
                    } /* JsonParserGenerator.kt:685 */
   36     63   
                }
          64  +
                /* JsonParserGenerator.kt:684 */
   37     65   
            }
   38         -
            }
          66  +
            /* JsonParserGenerator.kt:540 */
   39     67   
            Ok(Some(
   40     68   
                crate::serde_util::continuous_backups_description_correct_errors(builder)
   41     69   
                    .build()
   42     70   
                    .map_err(|err| ::aws_smithy_json::deserialize::error::DeserializeError::custom_source("Response was invalid", err))?,
   43     71   
            ))
          72  +
            /* JsonParserGenerator.kt:713 */
   44     73   
        }
   45         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
          74  +
        /* JsonParserGenerator.kt:722 */
          75  +
        _ => {
          76  +
            /* JsonParserGenerator.kt:723 */
          77  +
            Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   46     78   
                "expected start object or null",
   47         -
        )),
          79  +
            ))
          80  +
            /* JsonParserGenerator.kt:722 */
          81  +
        } /* JsonParserGenerator.kt:712 */
   48     82   
    }
          83  +
    /* JsonParserGenerator.kt:516 */
   49     84   
}

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

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

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

@@ -1,1 +34,59 @@
    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_contributor_insights_rule_list<'a, I>(
    3      4   
    tokens: &mut ::std::iter::Peekable<I>,
    4      5   
) -> ::std::result::Result<Option<::std::vec::Vec<::std::string::String>>, ::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 = ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   20         -
                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   21         -
                            .transpose()?;
          28  +
                        /* JsonParserGenerator.kt:419 */
          29  +
                        let value =
          30  +
                            /* JsonParserGenerator.kt:354 */::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?.map(|s|
          31  +
                                /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          32  +
                                    /* JsonParserGenerator.kt:348 */u.into_owned()
          33  +
                                /* JsonParserGenerator.kt:339 */)
          34  +
                            /* JsonParserGenerator.kt:354 */).transpose()?
          35  +
                        /* JsonParserGenerator.kt:419 */;
          36  +
                        /* JsonParserGenerator.kt:422 */
   22     37   
                        if let Some(value) = value {
   23     38   
                            items.push(value);
   24     39   
                        }
          40  +
                        /* JsonParserGenerator.kt:413 */
          41  +
                    } /* JsonParserGenerator.kt:409 */
   25     42   
                }
          43  +
                /* JsonParserGenerator.kt:408 */
   26     44   
            }
   27         -
            }
          45  +
            /* JsonParserGenerator.kt:446 */
   28     46   
            Ok(Some(items))
          47  +
            /* JsonParserGenerator.kt:713 */
   29     48   
        }
   30         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
          49  +
        /* JsonParserGenerator.kt:722 */
          50  +
        _ => {
          51  +
            /* JsonParserGenerator.kt:723 */
          52  +
            Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   31     53   
                "expected start array or null",
   32         -
        )),
          54  +
            ))
          55  +
            /* JsonParserGenerator.kt:722 */
          56  +
        } /* JsonParserGenerator.kt:712 */
   33     57   
    }
          58  +
    /* JsonParserGenerator.kt:398 */
   34     59   
}

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_contributor_insights_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_contributor_insights_summaries<'a, I>(
    3      4   
    tokens: &mut ::std::iter::Peekable<I>,
    4      5   
) -> ::std::result::Result<Option<::std::vec::Vec<crate::types::ContributorInsightsSummary>>, ::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_contributor_insights_summary::de_contributor_insights_summary(tokens)?;
          28  +
                        /* JsonParserGenerator.kt:419 */
          29  +
                        let value =
          30  +
                            /* JsonParserGenerator.kt:544 */crate::protocol_serde::shape_contributor_insights_summary::de_contributor_insights_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_contributor_insights_summary.rs

@@ -1,1 +54,96 @@
    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_contributor_insights_summary<'a, I>(
    3      4   
    tokens: &mut ::std::iter::Peekable<I>,
    4      5   
) -> ::std::result::Result<Option<crate::types::ContributorInsightsSummary>, ::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::ContributorInsightsSummaryBuilder::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   
                            "IndexName" => {
          41  +
                                /* JsonParserGenerator.kt:265 */
   25     42   
                                builder = builder.set_index_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   
                            "ContributorInsightsStatus" => {
          55  +
                                /* JsonParserGenerator.kt:265 */
   32     56   
                                builder = builder.set_contributor_insights_status(
          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| crate::types::ContributorInsightsStatus::from(u.as_ref())))
   35         -
                                    .transpose()?,
          59  +
                                        .map(|s|
          60  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          61  +
                                            /* JsonParserGenerator.kt:345 */crate::types::ContributorInsightsStatus::from(u.as_ref())
          62  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
          63  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
   36     64   
                                );
          65  +
                                /* JsonParserGenerator.kt:262 */
   37     66   
                            }
   38         -
                        _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   39         -
                    },
          67  +
                            /* JsonParserGenerator.kt:290 */
          68  +
                            _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
          69  +
                        }
          70  +
                        /* JsonParserGenerator.kt:686 */
          71  +
                    }
          72  +
                    /* JsonParserGenerator.kt:695 */
   40     73   
                    other => {
   41     74   
                        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   42     75   
                            "expected object key or end object, found: {:?}",
   43     76   
                            other
   44     77   
                        )))
          78  +
                    } /* JsonParserGenerator.kt:685 */
   45     79   
                }
          80  +
                /* JsonParserGenerator.kt:684 */
   46     81   
            }
   47         -
            }
          82  +
            /* JsonParserGenerator.kt:540 */
   48     83   
            Ok(Some(builder.build()))
          84  +
            /* JsonParserGenerator.kt:713 */
   49     85   
        }
   50         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
          86  +
        /* JsonParserGenerator.kt:722 */
          87  +
        _ => {
          88  +
            /* JsonParserGenerator.kt:723 */
          89  +
            Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   51     90   
                "expected start object or null",
   52         -
        )),
          91  +
            ))
          92  +
            /* JsonParserGenerator.kt:722 */
          93  +
        } /* JsonParserGenerator.kt:712 */
   53     94   
    }
          95  +
    /* JsonParserGenerator.kt:516 */
   54     96   
}

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

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

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

@@ -1,1 +13,22 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_create_backup_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::create_backup::CreateBackupInput,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.table_name {
           9  +
        /* JsonSerializerGenerator.kt:423 */
    7     10   
        object.key("TableName").string(var_1.as_str());
          11  +
        /* JsonSerializerGenerator.kt:382 */
    8     12   
    }
          13  +
    /* JsonSerializerGenerator.kt:382 */
    9     14   
    if let Some(var_2) = &input.backup_name {
          15  +
        /* JsonSerializerGenerator.kt:423 */
   10     16   
        object.key("BackupName").string(var_2.as_str());
          17  +
        /* JsonSerializerGenerator.kt:382 */
   11     18   
    }
          19  +
    /* JsonSerializerGenerator.kt:372 */
   12     20   
    Ok(())
          21  +
    /* JsonSerializerGenerator.kt:358 */
   13     22   
}

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

@@ -1,1 +34,64 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_create_global_secondary_index_action(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::types::CreateGlobalSecondaryIndexAction,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* SerializerUtil.kt:42 */
    6      8   
    {
           9  +
        /* JsonSerializerGenerator.kt:423 */
    7     10   
        object.key("IndexName").string(input.index_name.as_str());
          11  +
        /* SerializerUtil.kt:42 */
    8     12   
    }
          13  +
    /* SerializerUtil.kt:42 */
    9     14   
    {
          15  +
        /* JsonSerializerGenerator.kt:484 */
   10     16   
        let mut array_1 = object.key("KeySchema").start_array();
          17  +
        /* JsonSerializerGenerator.kt:524 */
   11     18   
        for item_2 in &input.key_schema {
          19  +
            /* SerializerUtil.kt:42 */
   12     20   
            {
          21  +
                /* JsonSerializerGenerator.kt:495 */
   13     22   
                #[allow(unused_mut)]
          23  +
                /* JsonSerializerGenerator.kt:496 */
   14     24   
                let mut object_3 = array_1.value().start_object();
          25  +
                /* JsonSerializerGenerator.kt:375 */
   15     26   
                crate::protocol_serde::shape_key_schema_element::ser_key_schema_element(&mut object_3, item_2)?;
          27  +
                /* JsonSerializerGenerator.kt:515 */
   16     28   
                object_3.finish();
          29  +
                /* SerializerUtil.kt:42 */
   17     30   
            }
          31  +
            /* JsonSerializerGenerator.kt:524 */
   18     32   
        }
          33  +
        /* JsonSerializerGenerator.kt:486 */
   19     34   
        array_1.finish();
          35  +
        /* SerializerUtil.kt:42 */
   20     36   
    }
          37  +
    /* SerializerUtil.kt:42 */
   21     38   
    {
          39  +
        /* JsonSerializerGenerator.kt:495 */
   22     40   
        #[allow(unused_mut)]
          41  +
        /* JsonSerializerGenerator.kt:496 */
   23     42   
        let mut object_4 = object.key("Projection").start_object();
          43  +
        /* JsonSerializerGenerator.kt:375 */
   24     44   
        crate::protocol_serde::shape_projection::ser_projection(&mut object_4, &input.projection)?;
          45  +
        /* JsonSerializerGenerator.kt:515 */
   25     46   
        object_4.finish();
          47  +
        /* SerializerUtil.kt:42 */
   26     48   
    }
          49  +
    /* JsonSerializerGenerator.kt:382 */
   27     50   
    if let Some(var_5) = &input.provisioned_throughput {
          51  +
        /* JsonSerializerGenerator.kt:495 */
   28     52   
        #[allow(unused_mut)]
          53  +
        /* JsonSerializerGenerator.kt:496 */
   29     54   
        let mut object_6 = object.key("ProvisionedThroughput").start_object();
          55  +
        /* JsonSerializerGenerator.kt:375 */
   30     56   
        crate::protocol_serde::shape_provisioned_throughput::ser_provisioned_throughput(&mut object_6, var_5)?;
          57  +
        /* JsonSerializerGenerator.kt:515 */
   31     58   
        object_6.finish();
          59  +
        /* JsonSerializerGenerator.kt:382 */
   32     60   
    }
          61  +
    /* JsonSerializerGenerator.kt:372 */
   33     62   
    Ok(())
          63  +
    /* JsonSerializerGenerator.kt:358 */
   34     64   
}

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

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

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

@@ -1,1 +22,40 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_create_global_table_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::create_global_table::CreateGlobalTableInput,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.global_table_name {
           9  +
        /* JsonSerializerGenerator.kt:423 */
    7     10   
        object.key("GlobalTableName").string(var_1.as_str());
          11  +
        /* JsonSerializerGenerator.kt:382 */
    8     12   
    }
          13  +
    /* JsonSerializerGenerator.kt:382 */
    9     14   
    if let Some(var_2) = &input.replication_group {
          15  +
        /* JsonSerializerGenerator.kt:484 */
   10     16   
        let mut array_3 = object.key("ReplicationGroup").start_array();
          17  +
        /* JsonSerializerGenerator.kt:524 */
   11     18   
        for item_4 in var_2 {
          19  +
            /* SerializerUtil.kt:42 */
   12     20   
            {
          21  +
                /* JsonSerializerGenerator.kt:495 */
   13     22   
                #[allow(unused_mut)]
          23  +
                /* JsonSerializerGenerator.kt:496 */
   14     24   
                let mut object_5 = array_3.value().start_object();
          25  +
                /* JsonSerializerGenerator.kt:375 */
   15     26   
                crate::protocol_serde::shape_replica::ser_replica(&mut object_5, item_4)?;
          27  +
                /* JsonSerializerGenerator.kt:515 */
   16     28   
                object_5.finish();
          29  +
                /* SerializerUtil.kt:42 */
   17     30   
            }
          31  +
            /* JsonSerializerGenerator.kt:524 */
   18     32   
        }
          33  +
        /* JsonSerializerGenerator.kt:486 */
   19     34   
        array_3.finish();
          35  +
        /* JsonSerializerGenerator.kt:382 */
   20     36   
    }
          37  +
    /* JsonSerializerGenerator.kt:372 */
   21     38   
    Ok(())
          39  +
    /* JsonSerializerGenerator.kt:358 */
   22     40   
}

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

@@ -1,1 +10,16 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_create_replica_action(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::types::CreateReplicaAction,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* SerializerUtil.kt:42 */
    6      8   
    {
           9  +
        /* JsonSerializerGenerator.kt:423 */
    7     10   
        object.key("RegionName").string(input.region_name.as_str());
          11  +
        /* SerializerUtil.kt:42 */
    8     12   
    }
          13  +
    /* JsonSerializerGenerator.kt:372 */
    9     14   
    Ok(())
          15  +
    /* JsonSerializerGenerator.kt:358 */
   10     16   
}

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

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