Client Test

Client Test

rev. dfb5149b65b7bcc09edd15b8e071ad43b5ac5943 (ignoring whitespace)

Files changed:

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

@@ -1,1 +52,92 @@
    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_point_in_time_recovery_description<'a, I>(
    3      4   
    tokens: &mut ::std::iter::Peekable<I>,
    4      5   
) -> ::std::result::Result<Option<crate::types::PointInTimeRecoveryDescription>, ::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::PointInTimeRecoveryDescriptionBuilder::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   
                            "PointInTimeRecoveryStatus" => {
          27  +
                                /* JsonParserGenerator.kt:265 */
   18     28   
                                builder = builder.set_point_in_time_recovery_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::PointInTimeRecoveryStatus::from(u.as_ref())))
   21         -
                                    .transpose()?,
          31  +
                                        .map(|s|
          32  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          33  +
                                            /* JsonParserGenerator.kt:345 */crate::types::PointInTimeRecoveryStatus::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   
                            "EarliestRestorableDateTime" => {
   25         -
                            builder = builder.set_earliest_restorable_date_time(::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
          41  +
                                /* JsonParserGenerator.kt:265 */
          42  +
                                builder = builder.set_earliest_restorable_date_time(
          43  +
                                    /* JsonParserGenerator.kt:384 */
          44  +
                                    ::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
   26     45   
                                        tokens.next(),
   27     46   
                                        ::aws_smithy_types::date_time::Format::EpochSeconds,
   28         -
                            )?);
          47  +
                                    )?, /* JsonParserGenerator.kt:265 */
          48  +
                                );
          49  +
                                /* JsonParserGenerator.kt:262 */
   29     50   
                            }
          51  +
                            /* JsonParserGenerator.kt:262 */
   30     52   
                            "LatestRestorableDateTime" => {
   31         -
                            builder = builder.set_latest_restorable_date_time(::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
          53  +
                                /* JsonParserGenerator.kt:265 */
          54  +
                                builder = builder.set_latest_restorable_date_time(
          55  +
                                    /* JsonParserGenerator.kt:384 */
          56  +
                                    ::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
   32     57   
                                        tokens.next(),
   33     58   
                                        ::aws_smithy_types::date_time::Format::EpochSeconds,
   34         -
                            )?);
          59  +
                                    )?, /* JsonParserGenerator.kt:265 */
          60  +
                                );
          61  +
                                /* JsonParserGenerator.kt:262 */
          62  +
                            }
          63  +
                            /* JsonParserGenerator.kt:290 */
          64  +
                            _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
   35     65   
                        }
   36         -
                        _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   37         -
                    },
          66  +
                        /* JsonParserGenerator.kt:686 */
          67  +
                    }
          68  +
                    /* JsonParserGenerator.kt:695 */
   38     69   
                    other => {
   39     70   
                        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   40     71   
                            "expected object key or end object, found: {:?}",
   41     72   
                            other
   42     73   
                        )))
          74  +
                    } /* JsonParserGenerator.kt:685 */
   43     75   
                }
          76  +
                /* JsonParserGenerator.kt:684 */
   44     77   
            }
   45         -
            }
          78  +
            /* JsonParserGenerator.kt:540 */
   46     79   
            Ok(Some(builder.build()))
          80  +
            /* JsonParserGenerator.kt:713 */
   47     81   
        }
   48         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
          82  +
        /* JsonParserGenerator.kt:722 */
          83  +
        _ => {
          84  +
            /* JsonParserGenerator.kt:723 */
          85  +
            Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   49     86   
                "expected start object or null",
   50         -
        )),
          87  +
            ))
          88  +
            /* JsonParserGenerator.kt:722 */
          89  +
        } /* JsonParserGenerator.kt:712 */
   51     90   
    }
          91  +
    /* JsonParserGenerator.kt:516 */
   52     92   
}

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_point_in_time_recovery_specification.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_point_in_time_recovery_specification(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::types::PointInTimeRecoverySpecification,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* SerializerUtil.kt:42 */
    6      8   
    {
           9  +
        /* JsonSerializerGenerator.kt:424 */
    7     10   
        object.key("PointInTimeRecoveryEnabled").boolean(input.point_in_time_recovery_enabled);
          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_point_in_time_recovery_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_point_in_time_recovery_unavailable_exception_json_err(
    3      4   
    value: &[u8],
    4      5   
    mut builder: crate::types::error::builders::PointInTimeRecoveryUnavailableErrorBuilder,
    5      6   
) -> ::std::result::Result<
    6      7   
    crate::types::error::builders::PointInTimeRecoveryUnavailableErrorBuilder,
    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_projection.rs

@@ -1,1 +64,110 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_projection(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::types::Projection,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.projection_type {
           9  +
        /* JsonSerializerGenerator.kt:423 */
    7     10   
        object.key("ProjectionType").string(var_1.as_str());
          11  +
        /* JsonSerializerGenerator.kt:382 */
    8     12   
    }
          13  +
    /* JsonSerializerGenerator.kt:382 */
    9     14   
    if let Some(var_2) = &input.non_key_attributes {
          15  +
        /* JsonSerializerGenerator.kt:484 */
   10     16   
        let mut array_3 = object.key("NonKeyAttributes").start_array();
          17  +
        /* JsonSerializerGenerator.kt:524 */
   11     18   
        for item_4 in var_2 {
          19  +
            /* SerializerUtil.kt:42 */
   12     20   
            {
          21  +
                /* JsonSerializerGenerator.kt:423 */
   13     22   
                array_3.value().string(item_4.as_str());
          23  +
                /* SerializerUtil.kt:42 */
   14     24   
            }
          25  +
            /* JsonSerializerGenerator.kt:524 */
   15     26   
        }
          27  +
        /* JsonSerializerGenerator.kt:486 */
   16     28   
        array_3.finish();
          29  +
        /* JsonSerializerGenerator.kt:382 */
   17     30   
    }
          31  +
    /* JsonSerializerGenerator.kt:372 */
   18     32   
    Ok(())
          33  +
    /* JsonSerializerGenerator.kt:358 */
   19     34   
}
   20     35   
          36  +
/* JsonParserGenerator.kt:516 */
   21     37   
pub(crate) fn de_projection<'a, I>(
   22     38   
    tokens: &mut ::std::iter::Peekable<I>,
   23     39   
) -> ::std::result::Result<Option<crate::types::Projection>, ::aws_smithy_json::deserialize::error::DeserializeError>
   24     40   
where
   25     41   
    I: Iterator<Item = Result<::aws_smithy_json::deserialize::Token<'a>, ::aws_smithy_json::deserialize::error::DeserializeError>>,
   26     42   
{
          43  +
    /* JsonParserGenerator.kt:712 */
   27     44   
    match tokens.next().transpose()? {
   28         -
        Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
          45  +
        /* JsonParserGenerator.kt:713 */ Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
   29     46   
        Some(::aws_smithy_json::deserialize::Token::StartObject { .. }) => {
          47  +
            /* RustType.kt:516 */
   30     48   
            #[allow(unused_mut)]
          49  +
            /* JsonParserGenerator.kt:526 */
   31     50   
            let mut builder = crate::types::builders::ProjectionBuilder::default();
          51  +
            /* JsonParserGenerator.kt:684 */
   32     52   
            loop {
          53  +
                /* JsonParserGenerator.kt:685 */
   33     54   
                match tokens.next().transpose()? {
   34         -
                    Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   35         -
                    Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
          55  +
                    /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
          56  +
                    Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
          57  +
                        /* JsonParserGenerator.kt:260 */
          58  +
                        match key.to_unescaped()?.as_ref() {
          59  +
                            /* JsonParserGenerator.kt:262 */
   36     60   
                            "ProjectionType" => {
          61  +
                                /* JsonParserGenerator.kt:265 */
   37     62   
                                builder = builder.set_projection_type(
          63  +
                                    /* JsonParserGenerator.kt:354 */
   38     64   
                                    ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   39         -
                                    .map(|s| s.to_unescaped().map(|u| crate::types::ProjectionType::from(u.as_ref())))
   40         -
                                    .transpose()?,
          65  +
                                        .map(|s|
          66  +
                                        /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          67  +
                                            /* JsonParserGenerator.kt:345 */crate::types::ProjectionType::from(u.as_ref())
          68  +
                                        /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
          69  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
   41     70   
                                );
          71  +
                                /* JsonParserGenerator.kt:262 */
   42     72   
                            }
          73  +
                            /* JsonParserGenerator.kt:262 */
   43     74   
                            "NonKeyAttributes" => {
          75  +
                                /* JsonParserGenerator.kt:265 */
   44     76   
                                builder = builder.set_non_key_attributes(
   45         -
                                crate::protocol_serde::shape_non_key_attribute_name_list::de_non_key_attribute_name_list(tokens)?,
   46         -
                            );
          77  +
                                    /* JsonParserGenerator.kt:451 */crate::protocol_serde::shape_non_key_attribute_name_list::de_non_key_attribute_name_list(tokens)?
          78  +
                                /* JsonParserGenerator.kt:265 */);
          79  +
                                /* JsonParserGenerator.kt:262 */
          80  +
                            }
          81  +
                            /* JsonParserGenerator.kt:290 */
          82  +
                            _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
   47     83   
                        }
   48         -
                        _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   49         -
                    },
          84  +
                        /* JsonParserGenerator.kt:686 */
          85  +
                    }
          86  +
                    /* JsonParserGenerator.kt:695 */
   50     87   
                    other => {
   51     88   
                        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   52     89   
                            "expected object key or end object, found: {:?}",
   53     90   
                            other
   54     91   
                        )))
          92  +
                    } /* JsonParserGenerator.kt:685 */
   55     93   
                }
          94  +
                /* JsonParserGenerator.kt:684 */
   56     95   
            }
   57         -
            }
          96  +
            /* JsonParserGenerator.kt:540 */
   58     97   
            Ok(Some(builder.build()))
          98  +
            /* JsonParserGenerator.kt:713 */
   59     99   
        }
   60         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
         100  +
        /* JsonParserGenerator.kt:722 */
         101  +
        _ => {
         102  +
            /* JsonParserGenerator.kt:723 */
         103  +
            Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   61    104   
                "expected start object or null",
   62         -
        )),
         105  +
            ))
         106  +
            /* JsonParserGenerator.kt:722 */
         107  +
        } /* JsonParserGenerator.kt:712 */
   63    108   
    }
         109  +
    /* JsonParserGenerator.kt:516 */
   64    110   
}

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

@@ -1,1 +68,106 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_provisioned_throughput(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::types::ProvisionedThroughput,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* SerializerUtil.kt:42 */
    6      8   
    {
           9  +
        /* JsonSerializerGenerator.kt:432 */
    7     10   
        object.key("ReadCapacityUnits").number(
    8     11   
            #[allow(clippy::useless_conversion)]
    9     12   
            ::aws_smithy_types::Number::NegInt((input.read_capacity_units).into()),
   10     13   
        );
          14  +
        /* SerializerUtil.kt:42 */
   11     15   
    }
          16  +
    /* SerializerUtil.kt:42 */
   12     17   
    {
          18  +
        /* JsonSerializerGenerator.kt:432 */
   13     19   
        object.key("WriteCapacityUnits").number(
   14     20   
            #[allow(clippy::useless_conversion)]
   15     21   
            ::aws_smithy_types::Number::NegInt((input.write_capacity_units).into()),
   16     22   
        );
          23  +
        /* SerializerUtil.kt:42 */
   17     24   
    }
          25  +
    /* JsonSerializerGenerator.kt:372 */
   18     26   
    Ok(())
          27  +
    /* JsonSerializerGenerator.kt:358 */
   19     28   
}
   20     29   
          30  +
/* JsonParserGenerator.kt:516 */
   21     31   
pub(crate) fn de_provisioned_throughput<'a, I>(
   22     32   
    tokens: &mut ::std::iter::Peekable<I>,
   23     33   
) -> ::std::result::Result<Option<crate::types::ProvisionedThroughput>, ::aws_smithy_json::deserialize::error::DeserializeError>
   24     34   
where
   25     35   
    I: Iterator<Item = Result<::aws_smithy_json::deserialize::Token<'a>, ::aws_smithy_json::deserialize::error::DeserializeError>>,
   26     36   
{
          37  +
    /* JsonParserGenerator.kt:712 */
   27     38   
    match tokens.next().transpose()? {
   28         -
        Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
          39  +
        /* JsonParserGenerator.kt:713 */ Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
   29     40   
        Some(::aws_smithy_json::deserialize::Token::StartObject { .. }) => {
          41  +
            /* RustType.kt:516 */
   30     42   
            #[allow(unused_mut)]
          43  +
            /* JsonParserGenerator.kt:526 */
   31     44   
            let mut builder = crate::types::builders::ProvisionedThroughputBuilder::default();
          45  +
            /* JsonParserGenerator.kt:684 */
   32     46   
            loop {
          47  +
                /* JsonParserGenerator.kt:685 */
   33     48   
                match tokens.next().transpose()? {
   34         -
                    Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   35         -
                    Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
          49  +
                    /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
          50  +
                    Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
          51  +
                        /* JsonParserGenerator.kt:260 */
          52  +
                        match key.to_unescaped()?.as_ref() {
          53  +
                            /* JsonParserGenerator.kt:262 */
   36     54   
                            "ReadCapacityUnits" => {
          55  +
                                /* JsonParserGenerator.kt:265 */
   37     56   
                                builder = builder.set_read_capacity_units(
          57  +
                                    /* JsonParserGenerator.kt:365 */
   38     58   
                                    ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
   39     59   
                                        .map(i64::try_from)
   40         -
                                    .transpose()?,
          60  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
   41     61   
                                );
          62  +
                                /* JsonParserGenerator.kt:262 */
   42     63   
                            }
          64  +
                            /* JsonParserGenerator.kt:262 */
   43     65   
                            "WriteCapacityUnits" => {
          66  +
                                /* JsonParserGenerator.kt:265 */
   44     67   
                                builder = builder.set_write_capacity_units(
          68  +
                                    /* JsonParserGenerator.kt:365 */
   45     69   
                                    ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
   46     70   
                                        .map(i64::try_from)
   47         -
                                    .transpose()?,
          71  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
   48     72   
                                );
          73  +
                                /* JsonParserGenerator.kt:262 */
   49     74   
                            }
   50         -
                        _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   51         -
                    },
          75  +
                            /* JsonParserGenerator.kt:290 */
          76  +
                            _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
          77  +
                        }
          78  +
                        /* JsonParserGenerator.kt:686 */
          79  +
                    }
          80  +
                    /* JsonParserGenerator.kt:695 */
   52     81   
                    other => {
   53     82   
                        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   54     83   
                            "expected object key or end object, found: {:?}",
   55     84   
                            other
   56     85   
                        )))
          86  +
                    } /* JsonParserGenerator.kt:685 */
   57     87   
                }
          88  +
                /* JsonParserGenerator.kt:684 */
   58     89   
            }
   59         -
            }
          90  +
            /* JsonParserGenerator.kt:540 */
   60     91   
            Ok(Some(crate::serde_util::provisioned_throughput_correct_errors(builder).build().map_err(
   61     92   
                |err| ::aws_smithy_json::deserialize::error::DeserializeError::custom_source("Response was invalid", err),
   62     93   
            )?))
          94  +
            /* JsonParserGenerator.kt:713 */
   63     95   
        }
   64         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
          96  +
        /* JsonParserGenerator.kt:722 */
          97  +
        _ => {
          98  +
            /* JsonParserGenerator.kt:723 */
          99  +
            Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   65    100   
                "expected start object or null",
   66         -
        )),
         101  +
            ))
         102  +
            /* JsonParserGenerator.kt:722 */
         103  +
        } /* JsonParserGenerator.kt:712 */
   67    104   
    }
         105  +
    /* JsonParserGenerator.kt:516 */
   68    106   
}

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

@@ -1,1 +66,111 @@
    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_provisioned_throughput_description<'a, I>(
    3      4   
    tokens: &mut ::std::iter::Peekable<I>,
    4      5   
) -> ::std::result::Result<Option<crate::types::ProvisionedThroughputDescription>, ::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::ProvisionedThroughputDescriptionBuilder::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   
                            "LastIncreaseDateTime" => {
   18         -
                            builder = builder.set_last_increase_date_time(::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
          27  +
                                /* JsonParserGenerator.kt:265 */
          28  +
                                builder = builder.set_last_increase_date_time(
          29  +
                                    /* JsonParserGenerator.kt:384 */
          30  +
                                    ::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
   19     31   
                                        tokens.next(),
   20     32   
                                        ::aws_smithy_types::date_time::Format::EpochSeconds,
   21         -
                            )?);
          33  +
                                    )?, /* JsonParserGenerator.kt:265 */
          34  +
                                );
          35  +
                                /* JsonParserGenerator.kt:262 */
   22     36   
                            }
          37  +
                            /* JsonParserGenerator.kt:262 */
   23     38   
                            "LastDecreaseDateTime" => {
   24         -
                            builder = builder.set_last_decrease_date_time(::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
          39  +
                                /* JsonParserGenerator.kt:265 */
          40  +
                                builder = builder.set_last_decrease_date_time(
          41  +
                                    /* JsonParserGenerator.kt:384 */
          42  +
                                    ::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
   25     43   
                                        tokens.next(),
   26     44   
                                        ::aws_smithy_types::date_time::Format::EpochSeconds,
   27         -
                            )?);
          45  +
                                    )?, /* JsonParserGenerator.kt:265 */
          46  +
                                );
          47  +
                                /* JsonParserGenerator.kt:262 */
   28     48   
                            }
          49  +
                            /* JsonParserGenerator.kt:262 */
   29     50   
                            "NumberOfDecreasesToday" => {
          51  +
                                /* JsonParserGenerator.kt:265 */
   30     52   
                                builder = builder.set_number_of_decreases_today(
          53  +
                                    /* JsonParserGenerator.kt:365 */
   31     54   
                                    ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
   32     55   
                                        .map(i64::try_from)
   33         -
                                    .transpose()?,
          56  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
   34     57   
                                );
          58  +
                                /* JsonParserGenerator.kt:262 */
   35     59   
                            }
          60  +
                            /* JsonParserGenerator.kt:262 */
   36     61   
                            "ReadCapacityUnits" => {
          62  +
                                /* JsonParserGenerator.kt:265 */
   37     63   
                                builder = builder.set_read_capacity_units(
          64  +
                                    /* JsonParserGenerator.kt:365 */
   38     65   
                                    ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
   39     66   
                                        .map(i64::try_from)
   40         -
                                    .transpose()?,
          67  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
   41     68   
                                );
          69  +
                                /* JsonParserGenerator.kt:262 */
   42     70   
                            }
          71  +
                            /* JsonParserGenerator.kt:262 */
   43     72   
                            "WriteCapacityUnits" => {
          73  +
                                /* JsonParserGenerator.kt:265 */
   44     74   
                                builder = builder.set_write_capacity_units(
          75  +
                                    /* JsonParserGenerator.kt:365 */
   45     76   
                                    ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
   46     77   
                                        .map(i64::try_from)
   47         -
                                    .transpose()?,
          78  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
   48     79   
                                );
          80  +
                                /* JsonParserGenerator.kt:262 */
          81  +
                            }
          82  +
                            /* JsonParserGenerator.kt:290 */
          83  +
                            _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
   49     84   
                        }
   50         -
                        _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   51         -
                    },
          85  +
                        /* JsonParserGenerator.kt:686 */
          86  +
                    }
          87  +
                    /* JsonParserGenerator.kt:695 */
   52     88   
                    other => {
   53     89   
                        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   54     90   
                            "expected object key or end object, found: {:?}",
   55     91   
                            other
   56     92   
                        )))
          93  +
                    } /* JsonParserGenerator.kt:685 */
   57     94   
                }
          95  +
                /* JsonParserGenerator.kt:684 */
   58     96   
            }
   59         -
            }
          97  +
            /* JsonParserGenerator.kt:540 */
   60     98   
            Ok(Some(builder.build()))
          99  +
            /* JsonParserGenerator.kt:713 */
   61    100   
        }
   62         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
         101  +
        /* JsonParserGenerator.kt:722 */
         102  +
        _ => {
         103  +
            /* JsonParserGenerator.kt:723 */
         104  +
            Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   63    105   
                "expected start object or null",
   64         -
        )),
         106  +
            ))
         107  +
            /* JsonParserGenerator.kt:722 */
         108  +
        } /* JsonParserGenerator.kt:712 */
   65    109   
    }
         110  +
    /* JsonParserGenerator.kt:516 */
   66    111   
}

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_provisioned_throughput_exceeded_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_provisioned_throughput_exceeded_exception_json_err(
    3      4   
    value: &[u8],
    4      5   
    mut builder: crate::types::error::builders::ProvisionedThroughputExceededErrorBuilder,
    5      6   
) -> ::std::result::Result<
    6      7   
    crate::types::error::builders::ProvisionedThroughputExceededErrorBuilder,
    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_provisioned_throughput_override.rs

@@ -1,1 +53,84 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_provisioned_throughput_override(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::types::ProvisionedThroughputOverride,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.read_capacity_units {
           9  +
        /* JsonSerializerGenerator.kt:432 */
    7     10   
        object.key("ReadCapacityUnits").number(
    8     11   
            #[allow(clippy::useless_conversion)]
    9     12   
            ::aws_smithy_types::Number::NegInt((*var_1).into()),
   10     13   
        );
          14  +
        /* JsonSerializerGenerator.kt:382 */
   11     15   
    }
          16  +
    /* JsonSerializerGenerator.kt:372 */
   12     17   
    Ok(())
          18  +
    /* JsonSerializerGenerator.kt:358 */
   13     19   
}
   14     20   
          21  +
/* JsonParserGenerator.kt:516 */
   15     22   
pub(crate) fn de_provisioned_throughput_override<'a, I>(
   16     23   
    tokens: &mut ::std::iter::Peekable<I>,
   17     24   
) -> ::std::result::Result<Option<crate::types::ProvisionedThroughputOverride>, ::aws_smithy_json::deserialize::error::DeserializeError>
   18     25   
where
   19     26   
    I: Iterator<Item = Result<::aws_smithy_json::deserialize::Token<'a>, ::aws_smithy_json::deserialize::error::DeserializeError>>,
   20     27   
{
          28  +
    /* JsonParserGenerator.kt:712 */
   21     29   
    match tokens.next().transpose()? {
   22         -
        Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
          30  +
        /* JsonParserGenerator.kt:713 */ Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
   23     31   
        Some(::aws_smithy_json::deserialize::Token::StartObject { .. }) => {
          32  +
            /* RustType.kt:516 */
   24     33   
            #[allow(unused_mut)]
          34  +
            /* JsonParserGenerator.kt:526 */
   25     35   
            let mut builder = crate::types::builders::ProvisionedThroughputOverrideBuilder::default();
          36  +
            /* JsonParserGenerator.kt:684 */
   26     37   
            loop {
          38  +
                /* JsonParserGenerator.kt:685 */
   27     39   
                match tokens.next().transpose()? {
   28         -
                    Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   29         -
                    Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
          40  +
                    /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
          41  +
                    Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
          42  +
                        /* JsonParserGenerator.kt:260 */
          43  +
                        match key.to_unescaped()?.as_ref() {
          44  +
                            /* JsonParserGenerator.kt:262 */
   30     45   
                            "ReadCapacityUnits" => {
          46  +
                                /* JsonParserGenerator.kt:265 */
   31     47   
                                builder = builder.set_read_capacity_units(
          48  +
                                    /* JsonParserGenerator.kt:365 */
   32     49   
                                    ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
   33     50   
                                        .map(i64::try_from)
   34         -
                                    .transpose()?,
          51  +
                                        .transpose()?, /* JsonParserGenerator.kt:265 */
   35     52   
                                );
          53  +
                                /* JsonParserGenerator.kt:262 */
   36     54   
                            }
   37         -
                        _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   38         -
                    },
          55  +
                            /* JsonParserGenerator.kt:290 */
          56  +
                            _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
          57  +
                        }
          58  +
                        /* JsonParserGenerator.kt:686 */
          59  +
                    }
          60  +
                    /* JsonParserGenerator.kt:695 */
   39     61   
                    other => {
   40     62   
                        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   41     63   
                            "expected object key or end object, found: {:?}",
   42     64   
                            other
   43     65   
                        )))
          66  +
                    } /* JsonParserGenerator.kt:685 */
   44     67   
                }
          68  +
                /* JsonParserGenerator.kt:684 */
   45     69   
            }
   46         -
            }
          70  +
            /* JsonParserGenerator.kt:540 */
   47     71   
            Ok(Some(builder.build()))
          72  +
            /* JsonParserGenerator.kt:713 */
   48     73   
        }
   49         -
        _ => 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(
   50     78   
                "expected start object or null",
   51         -
        )),
          79  +
            ))
          80  +
            /* JsonParserGenerator.kt:722 */
          81  +
        } /* JsonParserGenerator.kt:712 */
   52     82   
    }
          83  +
    /* JsonParserGenerator.kt:516 */
   53     84   
}

tmp-codegen-diff/codegen-client-test/dynamo/rust-client-codegen/src/protocol_serde/shape_put.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_put(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::types::Put,
    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("Item").start_object();
          13  +
        /* JsonSerializerGenerator.kt:537 */
    9     14   
        for (key_2, value_3) in &input.item {
          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  +
    /* JsonSerializerGenerator.kt:382 */
   22     40   
    if let Some(var_5) = &input.condition_expression {
          41  +
        /* JsonSerializerGenerator.kt:423 */
   23     42   
        object.key("ConditionExpression").string(var_5.as_str());
          43  +
        /* JsonSerializerGenerator.kt:382 */
   24     44   
    }
          45  +
    /* JsonSerializerGenerator.kt:382 */
   25     46   
    if let Some(var_6) = &input.expression_attribute_names {
          47  +
        /* JsonSerializerGenerator.kt:495 */
   26     48   
        #[allow(unused_mut)]
          49  +
        /* JsonSerializerGenerator.kt:496 */
   27     50   
        let mut object_7 = object.key("ExpressionAttributeNames").start_object();
          51  +
        /* JsonSerializerGenerator.kt:537 */
   28     52   
        for (key_8, value_9) in var_6 {
          53  +
            /* SerializerUtil.kt:42 */
   29     54   
            {
          55  +
                /* JsonSerializerGenerator.kt:423 */
   30     56   
                object_7.key(key_8.as_str()).string(value_9.as_str());
          57  +
                /* SerializerUtil.kt:42 */
   31     58   
            }
          59  +
            /* JsonSerializerGenerator.kt:537 */
   32     60   
        }
          61  +
        /* JsonSerializerGenerator.kt:515 */
   33     62   
        object_7.finish();
          63  +
        /* JsonSerializerGenerator.kt:382 */
   34     64   
    }
          65  +
    /* JsonSerializerGenerator.kt:382 */
   35     66   
    if let Some(var_10) = &input.expression_attribute_values {
          67  +
        /* JsonSerializerGenerator.kt:495 */
   36     68   
        #[allow(unused_mut)]
          69  +
        /* JsonSerializerGenerator.kt:496 */
   37     70   
        let mut object_11 = object.key("ExpressionAttributeValues").start_object();
          71  +
        /* JsonSerializerGenerator.kt:537 */
   38     72   
        for (key_12, value_13) in var_10 {
          73  +
            /* SerializerUtil.kt:42 */
   39     74   
            {
          75  +
                /* JsonSerializerGenerator.kt:495 */
   40     76   
                #[allow(unused_mut)]
          77  +
                /* JsonSerializerGenerator.kt:496 */
   41     78   
                let mut object_14 = object_11.key(key_12.as_str()).start_object();
          79  +
                /* JsonSerializerGenerator.kt:579 */
   42     80   
                crate::protocol_serde::shape_attribute_value::ser_attribute_value(&mut object_14, value_13)?;
          81  +
                /* JsonSerializerGenerator.kt:515 */
   43     82   
                object_14.finish();
          83  +
                /* SerializerUtil.kt:42 */
   44     84   
            }
          85  +
            /* JsonSerializerGenerator.kt:537 */
   45     86   
        }
          87  +
        /* JsonSerializerGenerator.kt:515 */
   46     88   
        object_11.finish();
          89  +
        /* JsonSerializerGenerator.kt:382 */
   47     90   
    }
          91  +
    /* JsonSerializerGenerator.kt:382 */
   48     92   
    if let Some(var_15) = &input.return_values_on_condition_check_failure {
          93  +
        /* JsonSerializerGenerator.kt:423 */
   49     94   
        object.key("ReturnValuesOnConditionCheckFailure").string(var_15.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_put_item.rs

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

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

@@ -1,1 +74,144 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_put_item_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::put_item::PutItemInput,
    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.item {
          15  +
        /* JsonSerializerGenerator.kt:495 */
   10     16   
        #[allow(unused_mut)]
          17  +
        /* JsonSerializerGenerator.kt:496 */
   11     18   
        let mut object_3 = object.key("Item").start_object();
          19  +
        /* JsonSerializerGenerator.kt:537 */
   12     20   
        for (key_4, value_5) in var_2 {
          21  +
            /* SerializerUtil.kt:42 */
   13     22   
            {
          23  +
                /* JsonSerializerGenerator.kt:495 */
   14     24   
                #[allow(unused_mut)]
          25  +
                /* JsonSerializerGenerator.kt:496 */
   15     26   
                let mut object_6 = object_3.key(key_4.as_str()).start_object();
          27  +
                /* JsonSerializerGenerator.kt:579 */
   16     28   
                crate::protocol_serde::shape_attribute_value::ser_attribute_value(&mut object_6, value_5)?;
          29  +
                /* JsonSerializerGenerator.kt:515 */
   17     30   
                object_6.finish();
          31  +
                /* SerializerUtil.kt:42 */
   18     32   
            }
          33  +
            /* JsonSerializerGenerator.kt:537 */
   19     34   
        }
          35  +
        /* JsonSerializerGenerator.kt:515 */
   20     36   
        object_3.finish();
          37  +
        /* JsonSerializerGenerator.kt:382 */
   21     38   
    }
          39  +
    /* JsonSerializerGenerator.kt:382 */
   22     40   
    if let Some(var_7) = &input.expected {
          41  +
        /* JsonSerializerGenerator.kt:495 */
   23     42   
        #[allow(unused_mut)]
          43  +
        /* JsonSerializerGenerator.kt:496 */
   24     44   
        let mut object_8 = object.key("Expected").start_object();
          45  +
        /* JsonSerializerGenerator.kt:537 */
   25     46   
        for (key_9, value_10) in var_7 {
          47  +
            /* SerializerUtil.kt:42 */
   26     48   
            {
          49  +
                /* JsonSerializerGenerator.kt:495 */
   27     50   
                #[allow(unused_mut)]
          51  +
                /* JsonSerializerGenerator.kt:496 */
   28     52   
                let mut object_11 = object_8.key(key_9.as_str()).start_object();
          53  +
                /* JsonSerializerGenerator.kt:375 */
   29     54   
                crate::protocol_serde::shape_expected_attribute_value::ser_expected_attribute_value(&mut object_11, value_10)?;
          55  +
                /* JsonSerializerGenerator.kt:515 */
   30     56   
                object_11.finish();
          57  +
                /* SerializerUtil.kt:42 */
   31     58   
            }
          59  +
            /* JsonSerializerGenerator.kt:537 */
   32     60   
        }
          61  +
        /* JsonSerializerGenerator.kt:515 */
   33     62   
        object_8.finish();
          63  +
        /* JsonSerializerGenerator.kt:382 */
   34     64   
    }
          65  +
    /* JsonSerializerGenerator.kt:382 */
   35     66   
    if let Some(var_12) = &input.return_values {
          67  +
        /* JsonSerializerGenerator.kt:423 */
   36     68   
        object.key("ReturnValues").string(var_12.as_str());
          69  +
        /* JsonSerializerGenerator.kt:382 */
   37     70   
    }
          71  +
    /* JsonSerializerGenerator.kt:382 */
   38     72   
    if let Some(var_13) = &input.return_consumed_capacity {
          73  +
        /* JsonSerializerGenerator.kt:423 */
   39     74   
        object.key("ReturnConsumedCapacity").string(var_13.as_str());
          75  +
        /* JsonSerializerGenerator.kt:382 */
   40     76   
    }
          77  +
    /* JsonSerializerGenerator.kt:382 */
   41     78   
    if let Some(var_14) = &input.return_item_collection_metrics {
          79  +
        /* JsonSerializerGenerator.kt:423 */
   42     80   
        object.key("ReturnItemCollectionMetrics").string(var_14.as_str());
          81  +
        /* JsonSerializerGenerator.kt:382 */
   43     82   
    }
          83  +
    /* JsonSerializerGenerator.kt:382 */
   44     84   
    if let Some(var_15) = &input.conditional_operator {
          85  +
        /* JsonSerializerGenerator.kt:423 */
   45     86   
        object.key("ConditionalOperator").string(var_15.as_str());
          87  +
        /* JsonSerializerGenerator.kt:382 */
   46     88   
    }
          89  +
    /* JsonSerializerGenerator.kt:382 */
   47     90   
    if let Some(var_16) = &input.condition_expression {
          91  +
        /* JsonSerializerGenerator.kt:423 */
   48     92   
        object.key("ConditionExpression").string(var_16.as_str());
          93  +
        /* JsonSerializerGenerator.kt:382 */
   49     94   
    }
          95  +
    /* JsonSerializerGenerator.kt:382 */
   50     96   
    if let Some(var_17) = &input.expression_attribute_names {
          97  +
        /* JsonSerializerGenerator.kt:495 */
   51     98   
        #[allow(unused_mut)]
          99  +
        /* JsonSerializerGenerator.kt:496 */
   52    100   
        let mut object_18 = object.key("ExpressionAttributeNames").start_object();
         101  +
        /* JsonSerializerGenerator.kt:537 */
   53    102   
        for (key_19, value_20) in var_17 {
         103  +
            /* SerializerUtil.kt:42 */
   54    104   
            {
         105  +
                /* JsonSerializerGenerator.kt:423 */
   55    106   
                object_18.key(key_19.as_str()).string(value_20.as_str());
         107  +
                /* SerializerUtil.kt:42 */
   56    108   
            }
         109  +
            /* JsonSerializerGenerator.kt:537 */
   57    110   
        }
         111  +
        /* JsonSerializerGenerator.kt:515 */
   58    112   
        object_18.finish();
         113  +
        /* JsonSerializerGenerator.kt:382 */
   59    114   
    }
         115  +
    /* JsonSerializerGenerator.kt:382 */
   60    116   
    if let Some(var_21) = &input.expression_attribute_values {
         117  +
        /* JsonSerializerGenerator.kt:495 */
   61    118   
        #[allow(unused_mut)]
         119  +
        /* JsonSerializerGenerator.kt:496 */
   62    120   
        let mut object_22 = object.key("ExpressionAttributeValues").start_object();
         121  +
        /* JsonSerializerGenerator.kt:537 */
   63    122   
        for (key_23, value_24) in var_21 {
         123  +
            /* SerializerUtil.kt:42 */
   64    124   
            {
         125  +
                /* JsonSerializerGenerator.kt:495 */
   65    126   
                #[allow(unused_mut)]
         127  +
                /* JsonSerializerGenerator.kt:496 */
   66    128   
                let mut object_25 = object_22.key(key_23.as_str()).start_object();
         129  +
                /* JsonSerializerGenerator.kt:579 */
   67    130   
                crate::protocol_serde::shape_attribute_value::ser_attribute_value(&mut object_25, value_24)?;
         131  +
                /* JsonSerializerGenerator.kt:515 */
   68    132   
                object_25.finish();
         133  +
                /* SerializerUtil.kt:42 */
   69    134   
            }
         135  +
            /* JsonSerializerGenerator.kt:537 */
   70    136   
        }
         137  +
        /* JsonSerializerGenerator.kt:515 */
   71    138   
        object_22.finish();
         139  +
        /* JsonSerializerGenerator.kt:382 */
   72    140   
    }
         141  +
    /* JsonSerializerGenerator.kt:372 */
   73    142   
    Ok(())
         143  +
    /* JsonSerializerGenerator.kt:358 */
   74    144   
}

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

@@ -1,1 +39,64 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonParserGenerator.kt:460 */
    2      3   
pub(crate) fn de_put_item_input_attribute_map<'a, I>(
    3      4   
    tokens: &mut ::std::iter::Peekable<I>,
    4      5   
) -> ::std::result::Result<
    5      6   
    Option<::std::collections::HashMap<::std::string::String, crate::types::AttributeValue>>,
    6      7   
    ::aws_smithy_json::deserialize::error::DeserializeError,
    7      8   
>
    8      9   
where
    9     10   
    I: Iterator<Item = Result<::aws_smithy_json::deserialize::Token<'a>, ::aws_smithy_json::deserialize::error::DeserializeError>>,
   10     11   
{
          12  +
    /* JsonParserGenerator.kt:712 */
   11     13   
    match tokens.next().transpose()? {
   12         -
        Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
          14  +
        /* JsonParserGenerator.kt:713 */ Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
   13     15   
        Some(::aws_smithy_json::deserialize::Token::StartObject { .. }) => {
          16  +
            /* JsonParserGenerator.kt:469 */
   14     17   
            let mut map = ::std::collections::HashMap::new();
          18  +
            /* JsonParserGenerator.kt:684 */
   15     19   
            loop {
          20  +
                /* JsonParserGenerator.kt:685 */
   16     21   
                match tokens.next().transpose()? {
   17         -
                    Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
          22  +
                    /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   18     23   
                    Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
   19         -
                        let key = key.to_unescaped().map(|u| u.into_owned())?;
   20         -
                        let value = crate::protocol_serde::shape_attribute_value::de_attribute_value(tokens)?;
          24  +
                        /* JsonParserGenerator.kt:471 */
          25  +
                        let key =
          26  +
                            /* JsonParserGenerator.kt:339 */key.to_unescaped().map(|u|
          27  +
                                /* JsonParserGenerator.kt:348 */u.into_owned()
          28  +
                            /* JsonParserGenerator.kt:339 */)
          29  +
                        /* JsonParserGenerator.kt:471 */?;
          30  +
                        /* JsonParserGenerator.kt:474 */
          31  +
                        let value =
          32  +
                            /* JsonParserGenerator.kt:660 */crate::protocol_serde::shape_attribute_value::de_attribute_value(tokens)?
          33  +
                        /* JsonParserGenerator.kt:474 */;
          34  +
                        /* JsonParserGenerator.kt:491 */
   21     35   
                        if let Some(value) = value {
   22     36   
                            map.insert(key, value);
   23     37   
                        }
          38  +
                        /* JsonParserGenerator.kt:686 */
   24     39   
                    }
          40  +
                    /* JsonParserGenerator.kt:695 */
   25     41   
                    other => {
   26     42   
                        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   27     43   
                            "expected object key or end object, found: {:?}",
   28     44   
                            other
   29     45   
                        )))
          46  +
                    } /* JsonParserGenerator.kt:685 */
   30     47   
                }
          48  +
                /* JsonParserGenerator.kt:684 */
   31     49   
            }
   32         -
            }
          50  +
            /* JsonParserGenerator.kt:504 */
   33     51   
            Ok(Some(map))
          52  +
            /* JsonParserGenerator.kt:713 */
   34     53   
        }
   35         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
          54  +
        /* JsonParserGenerator.kt:722 */
          55  +
        _ => {
          56  +
            /* JsonParserGenerator.kt:723 */
          57  +
            Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   36     58   
                "expected start object or null",
   37         -
        )),
          59  +
            ))
          60  +
            /* JsonParserGenerator.kt:722 */
          61  +
        } /* JsonParserGenerator.kt:712 */
   38     62   
    }
          63  +
    /* JsonParserGenerator.kt:460 */
   39     64   
}

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

@@ -1,1 +59,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_put_request(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::types::PutRequest,
    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("Item").start_object();
          13  +
        /* JsonSerializerGenerator.kt:537 */
    9     14   
        for (key_2, value_3) in &input.item {
          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  +
    /* JsonSerializerGenerator.kt:372 */
   19     34   
    Ok(())
          35  +
    /* JsonSerializerGenerator.kt:358 */
   20     36   
}
   21     37   
          38  +
/* JsonParserGenerator.kt:516 */
   22     39   
pub(crate) fn de_put_request<'a, I>(
   23     40   
    tokens: &mut ::std::iter::Peekable<I>,
   24     41   
) -> ::std::result::Result<Option<crate::types::PutRequest>, ::aws_smithy_json::deserialize::error::DeserializeError>
   25     42   
where
   26     43   
    I: Iterator<Item = Result<::aws_smithy_json::deserialize::Token<'a>, ::aws_smithy_json::deserialize::error::DeserializeError>>,
   27     44   
{
          45  +
    /* JsonParserGenerator.kt:712 */
   28     46   
    match tokens.next().transpose()? {
   29         -
        Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
          47  +
        /* JsonParserGenerator.kt:713 */ Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
   30     48   
        Some(::aws_smithy_json::deserialize::Token::StartObject { .. }) => {
          49  +
            /* RustType.kt:516 */
   31     50   
            #[allow(unused_mut)]
          51  +
            /* JsonParserGenerator.kt:526 */
   32     52   
            let mut builder = crate::types::builders::PutRequestBuilder::default();
          53  +
            /* JsonParserGenerator.kt:684 */
   33     54   
            loop {
          55  +
                /* JsonParserGenerator.kt:685 */
   34     56   
                match tokens.next().transpose()? {
   35         -
                    Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   36         -
                    Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
          57  +
                    /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
          58  +
                    Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
          59  +
                        /* JsonParserGenerator.kt:260 */
          60  +
                        match key.to_unescaped()?.as_ref() {
          61  +
                            /* JsonParserGenerator.kt:262 */
   37     62   
                            "Item" => {
   38         -
                            builder =
   39         -
                                builder.set_item(crate::protocol_serde::shape_put_item_input_attribute_map::de_put_item_input_attribute_map(tokens)?);
          63  +
                                /* JsonParserGenerator.kt:265 */
          64  +
                                builder = builder.set_item(
          65  +
                                    /* JsonParserGenerator.kt:509 */crate::protocol_serde::shape_put_item_input_attribute_map::de_put_item_input_attribute_map(tokens)?
          66  +
                                /* JsonParserGenerator.kt:265 */);
          67  +
                                /* JsonParserGenerator.kt:262 */
   40     68   
                            }
   41         -
                        _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   42         -
                    },
          69  +
                            /* JsonParserGenerator.kt:290 */
          70  +
                            _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
          71  +
                        }
          72  +
                        /* JsonParserGenerator.kt:686 */
          73  +
                    }
          74  +
                    /* JsonParserGenerator.kt:695 */
   43     75   
                    other => {
   44     76   
                        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   45     77   
                            "expected object key or end object, found: {:?}",
   46     78   
                            other
   47     79   
                        )))
          80  +
                    } /* JsonParserGenerator.kt:685 */
   48     81   
                }
          82  +
                /* JsonParserGenerator.kt:684 */
   49     83   
            }
   50         -
            }
          84  +
            /* JsonParserGenerator.kt:540 */
   51     85   
            Ok(Some(crate::serde_util::put_request_correct_errors(builder).build().map_err(|err| {
   52     86   
                ::aws_smithy_json::deserialize::error::DeserializeError::custom_source("Response was invalid", err)
   53     87   
            })?))
          88  +
            /* JsonParserGenerator.kt:713 */
   54     89   
        }
   55         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
          90  +
        /* JsonParserGenerator.kt:722 */
          91  +
        _ => {
          92  +
            /* JsonParserGenerator.kt:723 */
          93  +
            Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   56     94   
                "expected start object or null",
   57         -
        )),
          95  +
            ))
          96  +
            /* JsonParserGenerator.kt:722 */
          97  +
        } /* JsonParserGenerator.kt:712 */
   58     98   
    }
          99  +
    /* JsonParserGenerator.kt:516 */
   59    100   
}

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

@@ -1,1 +173,269 @@
    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_query_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::query::QueryOutput, crate::operation::query::QueryError> {
          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::query::QueryError::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::query::QueryError::unhandled(generic)),
   15     21   
    };
   16     22   
   17     23   
    let _error_message = generic.message().map(|msg| msg.to_owned());
          24  +
    /* ProtocolParserGenerator.kt:133 */
   18     25   
    Err(match error_code {
          26  +
        /* ProtocolParserGenerator.kt:139 */
   19     27   
        "InternalServerError" => crate::operation::query::QueryError::InternalServerError({
          28  +
            /* RustType.kt:516 */
   20     29   
            #[allow(unused_mut)]
   21         -
            let mut tmp = {
   22         -
                #[allow(unused_mut)]
   23         -
                let mut output = crate::types::error::builders::InternalServerErrorBuilder::default();
   24         -
                output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output)
   25         -
                    .map_err(crate::operation::query::QueryError::unhandled)?;
   26         -
                let output = output.meta(generic);
   27         -
                output.build()
   28         -
            };
          30  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          31  +
                /* ProtocolParserGenerator.kt:146 */ {
          32  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          33  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::InternalServerErrorBuilder::default();
          34  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_internal_server_error::de_internal_server_error_json_err(_response_body, output).map_err(crate::operation::query::QueryError::unhandled)?;
          35  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          36  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
          37  +
                /* ProtocolParserGenerator.kt:146 */}
          38  +
            /* ProtocolParserGenerator.kt:145 */;
          39  +
            /* ProtocolParserGenerator.kt:170 */
   29     40   
            if tmp.message.is_none() {
   30     41   
                tmp.message = _error_message;
   31     42   
            }
          43  +
            /* ProtocolParserGenerator.kt:179 */
   32     44   
            tmp
          45  +
            /* ProtocolParserGenerator.kt:139 */
   33     46   
        }),
          47  +
        /* ProtocolParserGenerator.kt:139 */
   34     48   
        "InvalidEndpointException" => crate::operation::query::QueryError::InvalidEndpointError({
          49  +
            /* RustType.kt:516 */
   35     50   
            #[allow(unused_mut)]
   36         -
            let mut tmp = {
   37         -
                #[allow(unused_mut)]
   38         -
                let mut output = crate::types::error::builders::InvalidEndpointErrorBuilder::default();
   39         -
                output = crate::protocol_serde::shape_invalid_endpoint_exception::de_invalid_endpoint_exception_json_err(_response_body, output)
   40         -
                    .map_err(crate::operation::query::QueryError::unhandled)?;
   41         -
                let output = output.meta(generic);
   42         -
                output.build()
   43         -
            };
          51  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          52  +
                /* ProtocolParserGenerator.kt:146 */ {
          53  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          54  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::InvalidEndpointErrorBuilder::default();
          55  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_invalid_endpoint_exception::de_invalid_endpoint_exception_json_err(_response_body, output).map_err(crate::operation::query::QueryError::unhandled)?;
          56  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          57  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
          58  +
                /* ProtocolParserGenerator.kt:146 */}
          59  +
            /* ProtocolParserGenerator.kt:145 */;
          60  +
            /* ProtocolParserGenerator.kt:170 */
   44     61   
            if tmp.message.is_none() {
   45     62   
                tmp.message = _error_message;
   46     63   
            }
          64  +
            /* ProtocolParserGenerator.kt:179 */
   47     65   
            tmp
          66  +
            /* ProtocolParserGenerator.kt:139 */
   48     67   
        }),
   49         -
        "ProvisionedThroughputExceededException" => {
   50         -
            crate::operation::query::QueryError::ProvisionedThroughputExceededError({
   51         -
                #[allow(unused_mut)]
   52         -
                let mut tmp = {
          68  +
        /* ProtocolParserGenerator.kt:139 */
          69  +
        "ProvisionedThroughputExceededException" => crate::operation::query::QueryError::ProvisionedThroughputExceededError({
          70  +
            /* RustType.kt:516 */
   53     71   
            #[allow(unused_mut)]
   54         -
                    let mut output = crate::types::error::builders::ProvisionedThroughputExceededErrorBuilder::default();
   55         -
                    output = crate::protocol_serde::shape_provisioned_throughput_exceeded_exception::de_provisioned_throughput_exceeded_exception_json_err(_response_body, output).map_err(crate::operation::query::QueryError::unhandled)?;
   56         -
                    let output = output.meta(generic);
   57         -
                    output.build()
   58         -
                };
          72  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
          73  +
                /* ProtocolParserGenerator.kt:146 */ {
          74  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
          75  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::ProvisionedThroughputExceededErrorBuilder::default();
          76  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_provisioned_throughput_exceeded_exception::de_provisioned_throughput_exceeded_exception_json_err(_response_body, output).map_err(crate::operation::query::QueryError::unhandled)?;
          77  +
                    /* ProtocolParserGenerator.kt:157 */let output = output.meta(generic);
          78  +
                    /* ClientBuilderInstantiator.kt:56 */output.build()
          79  +
                /* ProtocolParserGenerator.kt:146 */}
          80  +
            /* ProtocolParserGenerator.kt:145 */;
          81  +
            /* ProtocolParserGenerator.kt:170 */
   59     82   
            if tmp.message.is_none() {
   60     83   
                tmp.message = _error_message;
   61     84   
            }
          85  +
            /* ProtocolParserGenerator.kt:179 */
   62     86   
            tmp
   63         -
            })
   64         -
        }
          87  +
            /* ProtocolParserGenerator.kt:139 */
          88  +
        }),
          89  +
        /* ProtocolParserGenerator.kt:139 */
   65     90   
        "RequestLimitExceeded" => crate::operation::query::QueryError::RequestLimitExceeded({
          91  +
            /* RustType.kt:516 */
   66     92   
            #[allow(unused_mut)]
   67         -
            let mut tmp = {
   68         -
                #[allow(unused_mut)]
   69         -
                let mut output = crate::types::error::builders::RequestLimitExceededBuilder::default();
   70         -
                output = crate::protocol_serde::shape_request_limit_exceeded::de_request_limit_exceeded_json_err(_response_body, output)
   71         -
                    .map_err(crate::operation::query::QueryError::unhandled)?;
   72         -
                let output = output.meta(generic);
   73         -
                output.build()
   74         -
            };
          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::RequestLimitExceededBuilder::default();
          97  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_request_limit_exceeded::de_request_limit_exceeded_json_err(_response_body, output).map_err(crate::operation::query::QueryError::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 */
   75    103   
            if tmp.message.is_none() {
   76    104   
                tmp.message = _error_message;
   77    105   
            }
         106  +
            /* ProtocolParserGenerator.kt:179 */
   78    107   
            tmp
         108  +
            /* ProtocolParserGenerator.kt:139 */
   79    109   
        }),
         110  +
        /* ProtocolParserGenerator.kt:139 */
   80    111   
        "ResourceNotFoundException" => crate::operation::query::QueryError::ResourceNotFoundError({
         112  +
            /* RustType.kt:516 */
   81    113   
            #[allow(unused_mut)]
   82         -
            let mut tmp = {
   83         -
                #[allow(unused_mut)]
   84         -
                let mut output = crate::types::error::builders::ResourceNotFoundErrorBuilder::default();
   85         -
                output = crate::protocol_serde::shape_resource_not_found_exception::de_resource_not_found_exception_json_err(_response_body, output)
   86         -
                    .map_err(crate::operation::query::QueryError::unhandled)?;
   87         -
                let output = output.meta(generic);
   88         -
                output.build()
   89         -
            };
         114  +
            /* ProtocolParserGenerator.kt:145 */let mut tmp =
         115  +
                /* ProtocolParserGenerator.kt:146 */ {
         116  +
                    /* RustType.kt:516 */#[allow(unused_mut)]
         117  +
                    /* ProtocolParserGenerator.kt:240 */let mut output = crate::types::error::builders::ResourceNotFoundErrorBuilder::default();
         118  +
                    /* ProtocolParserGenerator.kt:257 */output = crate::protocol_serde::shape_resource_not_found_exception::de_resource_not_found_exception_json_err(_response_body, output).map_err(crate::operation::query::QueryError::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 */
   90    124   
            if tmp.message.is_none() {
   91    125   
                tmp.message = _error_message;
   92    126   
            }
         127  +
            /* ProtocolParserGenerator.kt:179 */
   93    128   
            tmp
         129  +
            /* ProtocolParserGenerator.kt:139 */
   94    130   
        }),
   95         -
        _ => crate::operation::query::QueryError::generic(generic),
         131  +
        /* ProtocolParserGenerator.kt:182 */
         132  +
        _ => crate::operation::query::QueryError::generic(generic), /* ProtocolParserGenerator.kt:133 */
   96    133   
    })
         134  +
    /* ProtocolParserGenerator.kt:99 */
   97    135   
}
   98    136   
         137  +
/* RustType.kt:516 */
   99    138   
#[allow(clippy::unnecessary_wraps)]
         139  +
/* ProtocolParserGenerator.kt:71 */
  100    140   
pub fn de_query_http_response(
  101    141   
    _response_status: u16,
  102    142   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
  103    143   
    _response_body: &[u8],
  104    144   
) -> std::result::Result<crate::operation::query::QueryOutput, crate::operation::query::QueryError> {
         145  +
    /* ProtocolParserGenerator.kt:77 */
  105    146   
    Ok({
         147  +
        /* RustType.kt:516 */
  106    148   
        #[allow(unused_mut)]
         149  +
        /* ProtocolParserGenerator.kt:240 */
  107    150   
        let mut output = crate::operation::query::builders::QueryOutputBuilder::default();
         151  +
        /* ProtocolParserGenerator.kt:247 */
  108    152   
        output = crate::protocol_serde::shape_query::de_query(_response_body, output).map_err(crate::operation::query::QueryError::unhandled)?;
         153  +
        /* ClientBuilderInstantiator.kt:56 */
  109    154   
        output.build()
         155  +
        /* ProtocolParserGenerator.kt:77 */
  110    156   
    })
         157  +
    /* ProtocolParserGenerator.kt:71 */
  111    158   
}
  112    159   
         160  +
/* JsonSerializerGenerator.kt:287 */
  113    161   
pub fn ser_query_input(
  114    162   
    input: &crate::operation::query::QueryInput,
  115    163   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
         164  +
    /* JsonSerializerGenerator.kt:291 */
  116    165   
    let mut out = String::new();
         166  +
    /* JsonSerializerGenerator.kt:292 */
  117    167   
    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
         168  +
    /* JsonSerializerGenerator.kt:375 */
  118    169   
    crate::protocol_serde::shape_query_input::ser_query_input_input(&mut object, input)?;
         170  +
    /* JsonSerializerGenerator.kt:295 */
  119    171   
    object.finish();
         172  +
    /* JsonSerializerGenerator.kt:296 */
  120    173   
    Ok(::aws_smithy_types::body::SdkBody::from(out))
         174  +
    /* JsonSerializerGenerator.kt:287 */
  121    175   
}
  122    176   
         177  +
/* JsonParserGenerator.kt:148 */
  123    178   
pub(crate) fn de_query(
  124    179   
    value: &[u8],
  125    180   
    mut builder: crate::operation::query::builders::QueryOutputBuilder,
  126    181   
) -> ::std::result::Result<crate::operation::query::builders::QueryOutputBuilder, ::aws_smithy_json::deserialize::error::DeserializeError> {
         182  +
    /* JsonParserGenerator.kt:153 */
  127    183   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
  128    184   
    let tokens = &mut tokens_owned;
  129    185   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
         186  +
    /* JsonParserGenerator.kt:684 */
  130    187   
    loop {
         188  +
        /* JsonParserGenerator.kt:685 */
  131    189   
        match tokens.next().transpose()? {
  132         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
  133         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
         190  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
         191  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
         192  +
                /* JsonParserGenerator.kt:260 */
         193  +
                match key.to_unescaped()?.as_ref() {
         194  +
                    /* JsonParserGenerator.kt:262 */
  134    195   
                    "Items" => {
  135         -
                    builder = builder.set_items(crate::protocol_serde::shape_item_list::de_item_list(tokens)?);
         196  +
                        /* JsonParserGenerator.kt:265 */
         197  +
                        builder = builder.set_items(
         198  +
                            /* JsonParserGenerator.kt:451 */
         199  +
                            crate::protocol_serde::shape_item_list::de_item_list(tokens)?, /* JsonParserGenerator.kt:265 */
         200  +
                        );
         201  +
                        /* JsonParserGenerator.kt:262 */
  136    202   
                    }
         203  +
                    /* JsonParserGenerator.kt:262 */
  137    204   
                    "Count" => {
         205  +
                        /* JsonParserGenerator.kt:265 */
  138    206   
                        builder = builder.set_count(
         207  +
                            /* JsonParserGenerator.kt:365 */
  139    208   
                            ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
  140    209   
                                .map(i32::try_from)
  141         -
                            .transpose()?,
         210  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
  142    211   
                        );
         212  +
                        /* JsonParserGenerator.kt:262 */
  143    213   
                    }
         214  +
                    /* JsonParserGenerator.kt:262 */
  144    215   
                    "ScannedCount" => {
         216  +
                        /* JsonParserGenerator.kt:265 */
  145    217   
                        builder = builder.set_scanned_count(
         218  +
                            /* JsonParserGenerator.kt:365 */
  146    219   
                            ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
  147    220   
                                .map(i32::try_from)
  148         -
                            .transpose()?,
         221  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
  149    222   
                        );
         223  +
                        /* JsonParserGenerator.kt:262 */
  150    224   
                    }
         225  +
                    /* JsonParserGenerator.kt:262 */
  151    226   
                    "LastEvaluatedKey" => {
  152         -
                    builder = builder.set_last_evaluated_key(crate::protocol_serde::shape_key::de_key(tokens)?);
         227  +
                        /* JsonParserGenerator.kt:265 */
         228  +
                        builder = builder.set_last_evaluated_key(
         229  +
                            /* JsonParserGenerator.kt:509 */
         230  +
                            crate::protocol_serde::shape_key::de_key(tokens)?, /* JsonParserGenerator.kt:265 */
         231  +
                        );
         232  +
                        /* JsonParserGenerator.kt:262 */
  153    233   
                    }
         234  +
                    /* JsonParserGenerator.kt:262 */
  154    235   
                    "ConsumedCapacity" => {
  155         -
                    builder = builder.set_consumed_capacity(crate::protocol_serde::shape_consumed_capacity::de_consumed_capacity(tokens)?);
         236  +
                        /* JsonParserGenerator.kt:265 */
         237  +
                        builder = builder.set_consumed_capacity(
         238  +
                            /* JsonParserGenerator.kt:544 */
         239  +
                            crate::protocol_serde::shape_consumed_capacity::de_consumed_capacity(tokens)?, /* JsonParserGenerator.kt:265 */
         240  +
                        );
         241  +
                        /* JsonParserGenerator.kt:262 */
  156    242   
                    }
  157         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
  158         -
            },
         243  +
                    /* JsonParserGenerator.kt:290 */
         244  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
         245  +
                }
         246  +
                /* JsonParserGenerator.kt:686 */
         247  +
            }
         248  +
            /* JsonParserGenerator.kt:695 */
  159    249   
            other => {
  160    250   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
  161    251   
                    "expected object key or end object, found: {:?}",
  162    252   
                    other
  163    253   
                )))
         254  +
            } /* JsonParserGenerator.kt:685 */
  164    255   
        }
         256  +
        /* JsonParserGenerator.kt:684 */
  165    257   
    }
  166         -
    }
         258  +
    /* JsonParserGenerator.kt:250 */
  167    259   
    if tokens.next().is_some() {
         260  +
        /* JsonParserGenerator.kt:251 */
  168    261   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
  169    262   
            "found more JSON tokens after completing parsing",
  170    263   
        ));
         264  +
        /* JsonParserGenerator.kt:250 */
  171    265   
    }
         266  +
    /* JsonParserGenerator.kt:163 */
  172    267   
    Ok(builder)
         268  +
    /* JsonParserGenerator.kt:148 */
  173    269   
}