Client Test

Client Test

rev. dfb5149b65b7bcc09edd15b8e071ad43b5ac5943

Files changed:

tmp-codegen-diff/codegen-client-test/rest_json/rust-client-codegen/src/protocol_serde/shape_json_lists.rs

@@ -1,1 +94,187 @@
    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_json_lists_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::json_lists::JsonListsOutput, crate::operation::json_lists::JsonListsError> {
          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::json_lists::JsonListsError::unhandled)?;
          15  +
    /* ProtocolParserGenerator.kt:120 */
   11     16   
    let generic = generic_builder.build();
          17  +
    /* ProtocolParserGenerator.kt:185 */
   12     18   
    Err(crate::operation::json_lists::JsonListsError::generic(generic))
          19  +
    /* ProtocolParserGenerator.kt:99 */
   13     20   
}
   14     21   
          22  +
/* RustType.kt:516 */
   15     23   
#[allow(clippy::unnecessary_wraps)]
          24  +
/* ProtocolParserGenerator.kt:71 */
   16     25   
pub fn de_json_lists_http_response(
   17     26   
    _response_status: u16,
   18     27   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
   19     28   
    _response_body: &[u8],
   20     29   
) -> std::result::Result<crate::operation::json_lists::JsonListsOutput, crate::operation::json_lists::JsonListsError> {
          30  +
    /* ProtocolParserGenerator.kt:77 */
   21     31   
    Ok({
          32  +
        /* RustType.kt:516 */
   22     33   
        #[allow(unused_mut)]
          34  +
        /* ProtocolParserGenerator.kt:240 */
   23     35   
        let mut output = crate::operation::json_lists::builders::JsonListsOutputBuilder::default();
          36  +
        /* ProtocolParserGenerator.kt:247 */
   24     37   
        output = crate::protocol_serde::shape_json_lists::de_json_lists(_response_body, output)
   25     38   
            .map_err(crate::operation::json_lists::JsonListsError::unhandled)?;
          39  +
        /* ClientBuilderInstantiator.kt:56 */
   26     40   
        output.build()
          41  +
        /* ProtocolParserGenerator.kt:77 */
   27     42   
    })
          43  +
    /* ProtocolParserGenerator.kt:71 */
   28     44   
}
   29     45   
          46  +
/* JsonSerializerGenerator.kt:287 */
   30     47   
pub fn ser_json_lists_input(
   31     48   
    input: &crate::operation::json_lists::JsonListsInput,
   32     49   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
          50  +
    /* JsonSerializerGenerator.kt:291 */
   33     51   
    let mut out = String::new();
          52  +
    /* JsonSerializerGenerator.kt:292 */
   34     53   
    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
          54  +
    /* JsonSerializerGenerator.kt:375 */
   35     55   
    crate::protocol_serde::shape_json_lists_input::ser_json_lists_input_input(&mut object, input)?;
          56  +
    /* JsonSerializerGenerator.kt:295 */
   36     57   
    object.finish();
          58  +
    /* JsonSerializerGenerator.kt:296 */
   37     59   
    Ok(::aws_smithy_types::body::SdkBody::from(out))
          60  +
    /* JsonSerializerGenerator.kt:287 */
   38     61   
}
   39     62   
          63  +
/* JsonParserGenerator.kt:148 */
   40     64   
pub(crate) fn de_json_lists(
   41     65   
    value: &[u8],
   42     66   
    mut builder: crate::operation::json_lists::builders::JsonListsOutputBuilder,
   43     67   
) -> ::std::result::Result<crate::operation::json_lists::builders::JsonListsOutputBuilder, ::aws_smithy_json::deserialize::error::DeserializeError> {
          68  +
    /* JsonParserGenerator.kt:153 */
   44     69   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
   45     70   
    let tokens = &mut tokens_owned;
   46     71   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
          72  +
    /* JsonParserGenerator.kt:684 */
   47     73   
    loop {
          74  +
        /* JsonParserGenerator.kt:685 */
   48     75   
        match tokens.next().transpose()? {
   49         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   50         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
   51         -
                "booleanList" => {
   52         -
                    builder = builder.set_boolean_list(crate::protocol_serde::shape_boolean_list::de_boolean_list(tokens)?);
          76  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
          77  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
          78  +
                /* JsonParserGenerator.kt:260 */
          79  +
                match key.to_unescaped()?.as_ref() {
          80  +
                    /* JsonParserGenerator.kt:262 */
          81  +
                    "booleanList" => {
          82  +
                        /* JsonParserGenerator.kt:265 */
          83  +
                        builder = builder.set_boolean_list(
          84  +
                            /* JsonParserGenerator.kt:451 */
          85  +
                            crate::protocol_serde::shape_boolean_list::de_boolean_list(tokens)?, /* JsonParserGenerator.kt:265 */
          86  +
                        );
          87  +
                        /* JsonParserGenerator.kt:262 */
          88  +
                    }
          89  +
                    /* JsonParserGenerator.kt:262 */
          90  +
                    "enumList" => {
          91  +
                        /* JsonParserGenerator.kt:265 */
          92  +
                        builder = builder.set_enum_list(
          93  +
                            /* JsonParserGenerator.kt:451 */
          94  +
                            crate::protocol_serde::shape_foo_enum_list::de_foo_enum_list(tokens)?, /* JsonParserGenerator.kt:265 */
          95  +
                        );
          96  +
                        /* JsonParserGenerator.kt:262 */
          97  +
                    }
          98  +
                    /* JsonParserGenerator.kt:262 */
          99  +
                    "intEnumList" => {
         100  +
                        /* JsonParserGenerator.kt:265 */
         101  +
                        builder = builder.set_int_enum_list(
         102  +
                            /* JsonParserGenerator.kt:451 */
         103  +
                            crate::protocol_serde::shape_integer_enum_list::de_integer_enum_list(tokens)?, /* JsonParserGenerator.kt:265 */
         104  +
                        );
         105  +
                        /* JsonParserGenerator.kt:262 */
         106  +
                    }
         107  +
                    /* JsonParserGenerator.kt:262 */
         108  +
                    "integerList" => {
         109  +
                        /* JsonParserGenerator.kt:265 */
         110  +
                        builder = builder.set_integer_list(
         111  +
                            /* JsonParserGenerator.kt:451 */
         112  +
                            crate::protocol_serde::shape_integer_list::de_integer_list(tokens)?, /* JsonParserGenerator.kt:265 */
         113  +
                        );
         114  +
                        /* JsonParserGenerator.kt:262 */
         115  +
                    }
         116  +
                    /* JsonParserGenerator.kt:262 */
         117  +
                    "nestedStringList" => {
         118  +
                        /* JsonParserGenerator.kt:265 */
         119  +
                        builder = builder.set_nested_string_list(
         120  +
                            /* JsonParserGenerator.kt:451 */
         121  +
                            crate::protocol_serde::shape_nested_string_list::de_nested_string_list(tokens)?, /* JsonParserGenerator.kt:265 */
         122  +
                        );
         123  +
                        /* JsonParserGenerator.kt:262 */
         124  +
                    }
         125  +
                    /* JsonParserGenerator.kt:262 */
         126  +
                    "stringList" => {
         127  +
                        /* JsonParserGenerator.kt:265 */
         128  +
                        builder = builder.set_string_list(
         129  +
                            /* JsonParserGenerator.kt:451 */
         130  +
                            crate::protocol_serde::shape_string_list::de_string_list(tokens)?, /* JsonParserGenerator.kt:265 */
         131  +
                        );
         132  +
                        /* JsonParserGenerator.kt:262 */
         133  +
                    }
         134  +
                    /* JsonParserGenerator.kt:262 */
         135  +
                    "stringSet" => {
         136  +
                        /* JsonParserGenerator.kt:265 */
         137  +
                        builder = builder.set_string_set(
         138  +
                            /* JsonParserGenerator.kt:451 */
         139  +
                            crate::protocol_serde::shape_string_set::de_string_set(tokens)?, /* JsonParserGenerator.kt:265 */
         140  +
                        );
         141  +
                        /* JsonParserGenerator.kt:262 */
         142  +
                    }
         143  +
                    /* JsonParserGenerator.kt:262 */
         144  +
                    "myStructureList" => {
         145  +
                        /* JsonParserGenerator.kt:265 */
         146  +
                        builder = builder.set_structure_list(
         147  +
                            /* JsonParserGenerator.kt:451 */
         148  +
                            crate::protocol_serde::shape_structure_list::de_structure_list(tokens)?, /* JsonParserGenerator.kt:265 */
         149  +
                        );
         150  +
                        /* JsonParserGenerator.kt:262 */
         151  +
                    }
         152  +
                    /* JsonParserGenerator.kt:262 */
         153  +
                    "timestampList" => {
         154  +
                        /* JsonParserGenerator.kt:265 */
         155  +
                        builder = builder.set_timestamp_list(
         156  +
                            /* JsonParserGenerator.kt:451 */
         157  +
                            crate::protocol_serde::shape_timestamp_list::de_timestamp_list(tokens)?, /* JsonParserGenerator.kt:265 */
         158  +
                        );
         159  +
                        /* JsonParserGenerator.kt:262 */
         160  +
                    }
         161  +
                    /* JsonParserGenerator.kt:290 */
         162  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
   53    163   
                }
   54         -
                "enumList" => {
   55         -
                    builder = builder.set_enum_list(crate::protocol_serde::shape_foo_enum_list::de_foo_enum_list(tokens)?);
   56         -
                }
   57         -
                "intEnumList" => {
   58         -
                    builder = builder.set_int_enum_list(crate::protocol_serde::shape_integer_enum_list::de_integer_enum_list(tokens)?);
   59         -
                }
   60         -
                "integerList" => {
   61         -
                    builder = builder.set_integer_list(crate::protocol_serde::shape_integer_list::de_integer_list(tokens)?);
   62         -
                }
   63         -
                "nestedStringList" => {
   64         -
                    builder = builder.set_nested_string_list(crate::protocol_serde::shape_nested_string_list::de_nested_string_list(tokens)?);
   65         -
                }
   66         -
                "stringList" => {
   67         -
                    builder = builder.set_string_list(crate::protocol_serde::shape_string_list::de_string_list(tokens)?);
   68         -
                }
   69         -
                "stringSet" => {
   70         -
                    builder = builder.set_string_set(crate::protocol_serde::shape_string_set::de_string_set(tokens)?);
   71         -
                }
   72         -
                "myStructureList" => {
   73         -
                    builder = builder.set_structure_list(crate::protocol_serde::shape_structure_list::de_structure_list(tokens)?);
   74         -
                }
   75         -
                "timestampList" => {
   76         -
                    builder = builder.set_timestamp_list(crate::protocol_serde::shape_timestamp_list::de_timestamp_list(tokens)?);
   77         -
                }
   78         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   79         -
            },
         164  +
                /* JsonParserGenerator.kt:686 */
         165  +
            }
         166  +
            /* JsonParserGenerator.kt:695 */
   80    167   
            other => {
   81    168   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   82    169   
                    "expected object key or end object, found: {:?}",
   83    170   
                    other
   84    171   
                )))
   85         -
            }
         172  +
            } /* JsonParserGenerator.kt:685 */
   86    173   
        }
         174  +
        /* JsonParserGenerator.kt:684 */
   87    175   
    }
         176  +
    /* JsonParserGenerator.kt:250 */
   88    177   
    if tokens.next().is_some() {
         178  +
        /* JsonParserGenerator.kt:251 */
   89    179   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   90    180   
            "found more JSON tokens after completing parsing",
   91    181   
        ));
         182  +
        /* JsonParserGenerator.kt:250 */
   92    183   
    }
         184  +
    /* JsonParserGenerator.kt:163 */
   93    185   
    Ok(builder)
         186  +
    /* JsonParserGenerator.kt:148 */
   94    187   
}

tmp-codegen-diff/codegen-client-test/rest_json/rust-client-codegen/src/protocol_serde/shape_json_lists_input.rs

@@ -1,1 +103,196 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_json_lists_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::json_lists::JsonListsInput,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.boolean_list {
           9  +
        /* JsonSerializerGenerator.kt:484 */
    7     10   
        let mut array_2 = object.key("booleanList").start_array();
          11  +
        /* JsonSerializerGenerator.kt:524 */
    8     12   
        for item_3 in var_1 {
          13  +
            /* SerializerUtil.kt:42 */
    9     14   
            {
          15  +
                /* JsonSerializerGenerator.kt:424 */
   10     16   
                array_2.value().boolean(*item_3);
          17  +
                /* SerializerUtil.kt:42 */
   11     18   
            }
          19  +
            /* JsonSerializerGenerator.kt:524 */
   12     20   
        }
          21  +
        /* JsonSerializerGenerator.kt:486 */
   13     22   
        array_2.finish();
          23  +
        /* JsonSerializerGenerator.kt:382 */
   14     24   
    }
          25  +
    /* JsonSerializerGenerator.kt:382 */
   15     26   
    if let Some(var_4) = &input.enum_list {
          27  +
        /* JsonSerializerGenerator.kt:484 */
   16     28   
        let mut array_5 = object.key("enumList").start_array();
          29  +
        /* JsonSerializerGenerator.kt:524 */
   17     30   
        for item_6 in var_4 {
          31  +
            /* SerializerUtil.kt:42 */
   18     32   
            {
          33  +
                /* JsonSerializerGenerator.kt:423 */
   19     34   
                array_5.value().string(item_6.as_str());
          35  +
                /* SerializerUtil.kt:42 */
   20     36   
            }
          37  +
            /* JsonSerializerGenerator.kt:524 */
   21     38   
        }
          39  +
        /* JsonSerializerGenerator.kt:486 */
   22     40   
        array_5.finish();
          41  +
        /* JsonSerializerGenerator.kt:382 */
   23     42   
    }
          43  +
    /* JsonSerializerGenerator.kt:382 */
   24     44   
    if let Some(var_7) = &input.int_enum_list {
          45  +
        /* JsonSerializerGenerator.kt:484 */
   25     46   
        let mut array_8 = object.key("intEnumList").start_array();
          47  +
        /* JsonSerializerGenerator.kt:524 */
   26     48   
        for item_9 in var_7 {
          49  +
            /* SerializerUtil.kt:42 */
   27     50   
            {
          51  +
                /* JsonSerializerGenerator.kt:432 */
   28     52   
                array_8.value().number(
   29     53   
                    #[allow(clippy::useless_conversion)]
   30     54   
                    ::aws_smithy_types::Number::NegInt((*item_9).into()),
   31     55   
                );
          56  +
                /* SerializerUtil.kt:42 */
   32     57   
            }
          58  +
            /* JsonSerializerGenerator.kt:524 */
   33     59   
        }
          60  +
        /* JsonSerializerGenerator.kt:486 */
   34     61   
        array_8.finish();
          62  +
        /* JsonSerializerGenerator.kt:382 */
   35     63   
    }
          64  +
    /* JsonSerializerGenerator.kt:382 */
   36     65   
    if let Some(var_10) = &input.integer_list {
          66  +
        /* JsonSerializerGenerator.kt:484 */
   37     67   
        let mut array_11 = object.key("integerList").start_array();
          68  +
        /* JsonSerializerGenerator.kt:524 */
   38     69   
        for item_12 in var_10 {
          70  +
            /* SerializerUtil.kt:42 */
   39     71   
            {
          72  +
                /* JsonSerializerGenerator.kt:432 */
   40     73   
                array_11.value().number(
   41     74   
                    #[allow(clippy::useless_conversion)]
   42     75   
                    ::aws_smithy_types::Number::NegInt((*item_12).into()),
   43     76   
                );
          77  +
                /* SerializerUtil.kt:42 */
   44     78   
            }
          79  +
            /* JsonSerializerGenerator.kt:524 */
   45     80   
        }
          81  +
        /* JsonSerializerGenerator.kt:486 */
   46     82   
        array_11.finish();
          83  +
        /* JsonSerializerGenerator.kt:382 */
   47     84   
    }
          85  +
    /* JsonSerializerGenerator.kt:382 */
   48     86   
    if let Some(var_13) = &input.nested_string_list {
          87  +
        /* JsonSerializerGenerator.kt:484 */
   49     88   
        let mut array_14 = object.key("nestedStringList").start_array();
          89  +
        /* JsonSerializerGenerator.kt:524 */
   50     90   
        for item_15 in var_13 {
          91  +
            /* SerializerUtil.kt:42 */
   51     92   
            {
          93  +
                /* JsonSerializerGenerator.kt:484 */
   52     94   
                let mut array_16 = array_14.value().start_array();
          95  +
                /* JsonSerializerGenerator.kt:524 */
   53     96   
                for item_17 in item_15 {
          97  +
                    /* SerializerUtil.kt:42 */
   54     98   
                    {
          99  +
                        /* JsonSerializerGenerator.kt:423 */
   55    100   
                        array_16.value().string(item_17.as_str());
         101  +
                        /* SerializerUtil.kt:42 */
   56    102   
                    }
         103  +
                    /* JsonSerializerGenerator.kt:524 */
   57    104   
                }
         105  +
                /* JsonSerializerGenerator.kt:486 */
   58    106   
                array_16.finish();
         107  +
                /* SerializerUtil.kt:42 */
   59    108   
            }
         109  +
            /* JsonSerializerGenerator.kt:524 */
   60    110   
        }
         111  +
        /* JsonSerializerGenerator.kt:486 */
   61    112   
        array_14.finish();
         113  +
        /* JsonSerializerGenerator.kt:382 */
   62    114   
    }
         115  +
    /* JsonSerializerGenerator.kt:382 */
   63    116   
    if let Some(var_18) = &input.string_list {
         117  +
        /* JsonSerializerGenerator.kt:484 */
   64    118   
        let mut array_19 = object.key("stringList").start_array();
         119  +
        /* JsonSerializerGenerator.kt:524 */
   65    120   
        for item_20 in var_18 {
         121  +
            /* SerializerUtil.kt:42 */
   66    122   
            {
         123  +
                /* JsonSerializerGenerator.kt:423 */
   67    124   
                array_19.value().string(item_20.as_str());
         125  +
                /* SerializerUtil.kt:42 */
   68    126   
            }
         127  +
            /* JsonSerializerGenerator.kt:524 */
   69    128   
        }
         129  +
        /* JsonSerializerGenerator.kt:486 */
   70    130   
        array_19.finish();
         131  +
        /* JsonSerializerGenerator.kt:382 */
   71    132   
    }
         133  +
    /* JsonSerializerGenerator.kt:382 */
   72    134   
    if let Some(var_21) = &input.string_set {
         135  +
        /* JsonSerializerGenerator.kt:484 */
   73    136   
        let mut array_22 = object.key("stringSet").start_array();
         137  +
        /* JsonSerializerGenerator.kt:524 */
   74    138   
        for item_23 in var_21 {
         139  +
            /* SerializerUtil.kt:42 */
   75    140   
            {
         141  +
                /* JsonSerializerGenerator.kt:423 */
   76    142   
                array_22.value().string(item_23.as_str());
         143  +
                /* SerializerUtil.kt:42 */
   77    144   
            }
         145  +
            /* JsonSerializerGenerator.kt:524 */
   78    146   
        }
         147  +
        /* JsonSerializerGenerator.kt:486 */
   79    148   
        array_22.finish();
         149  +
        /* JsonSerializerGenerator.kt:382 */
   80    150   
    }
         151  +
    /* JsonSerializerGenerator.kt:382 */
   81    152   
    if let Some(var_24) = &input.structure_list {
         153  +
        /* JsonSerializerGenerator.kt:484 */
   82    154   
        let mut array_25 = object.key("myStructureList").start_array();
         155  +
        /* JsonSerializerGenerator.kt:524 */
   83    156   
        for item_26 in var_24 {
         157  +
            /* SerializerUtil.kt:42 */
   84    158   
            {
         159  +
                /* JsonSerializerGenerator.kt:495 */
   85    160   
                #[allow(unused_mut)]
         161  +
                /* JsonSerializerGenerator.kt:496 */
   86    162   
                let mut object_27 = array_25.value().start_object();
         163  +
                /* JsonSerializerGenerator.kt:375 */
   87    164   
                crate::protocol_serde::shape_structure_list_member::ser_structure_list_member(&mut object_27, item_26)?;
         165  +
                /* JsonSerializerGenerator.kt:515 */
   88    166   
                object_27.finish();
         167  +
                /* SerializerUtil.kt:42 */
   89    168   
            }
         169  +
            /* JsonSerializerGenerator.kt:524 */
   90    170   
        }
         171  +
        /* JsonSerializerGenerator.kt:486 */
   91    172   
        array_25.finish();
         173  +
        /* JsonSerializerGenerator.kt:382 */
   92    174   
    }
         175  +
    /* JsonSerializerGenerator.kt:382 */
   93    176   
    if let Some(var_28) = &input.timestamp_list {
         177  +
        /* JsonSerializerGenerator.kt:484 */
   94    178   
        let mut array_29 = object.key("timestampList").start_array();
         179  +
        /* JsonSerializerGenerator.kt:524 */
   95    180   
        for item_30 in var_28 {
         181  +
            /* SerializerUtil.kt:42 */
   96    182   
            {
         183  +
                /* JsonSerializerGenerator.kt:448 */
   97    184   
                array_29.value().date_time(item_30, ::aws_smithy_types::date_time::Format::EpochSeconds)?;
         185  +
                /* SerializerUtil.kt:42 */
   98    186   
            }
         187  +
            /* JsonSerializerGenerator.kt:524 */
   99    188   
        }
         189  +
        /* JsonSerializerGenerator.kt:486 */
  100    190   
        array_29.finish();
         191  +
        /* JsonSerializerGenerator.kt:382 */
  101    192   
    }
         193  +
    /* JsonSerializerGenerator.kt:372 */
  102    194   
    Ok(())
         195  +
    /* JsonSerializerGenerator.kt:358 */
  103    196   
}

tmp-codegen-diff/codegen-client-test/rest_json/rust-client-codegen/src/protocol_serde/shape_json_maps.rs

@@ -1,1 +82,151 @@
    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_json_maps_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::json_maps::JsonMapsOutput, crate::operation::json_maps::JsonMapsError> {
          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::json_maps::JsonMapsError::unhandled)?;
          15  +
    /* ProtocolParserGenerator.kt:120 */
   11     16   
    let generic = generic_builder.build();
          17  +
    /* ProtocolParserGenerator.kt:185 */
   12     18   
    Err(crate::operation::json_maps::JsonMapsError::generic(generic))
          19  +
    /* ProtocolParserGenerator.kt:99 */
   13     20   
}
   14     21   
          22  +
/* RustType.kt:516 */
   15     23   
#[allow(clippy::unnecessary_wraps)]
          24  +
/* ProtocolParserGenerator.kt:71 */
   16     25   
pub fn de_json_maps_http_response(
   17     26   
    _response_status: u16,
   18     27   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
   19     28   
    _response_body: &[u8],
   20     29   
) -> std::result::Result<crate::operation::json_maps::JsonMapsOutput, crate::operation::json_maps::JsonMapsError> {
          30  +
    /* ProtocolParserGenerator.kt:77 */
   21     31   
    Ok({
          32  +
        /* RustType.kt:516 */
   22     33   
        #[allow(unused_mut)]
          34  +
        /* ProtocolParserGenerator.kt:240 */
   23     35   
        let mut output = crate::operation::json_maps::builders::JsonMapsOutputBuilder::default();
          36  +
        /* ProtocolParserGenerator.kt:247 */
   24     37   
        output = crate::protocol_serde::shape_json_maps::de_json_maps(_response_body, output)
   25     38   
            .map_err(crate::operation::json_maps::JsonMapsError::unhandled)?;
          39  +
        /* ClientBuilderInstantiator.kt:56 */
   26     40   
        output.build()
          41  +
        /* ProtocolParserGenerator.kt:77 */
   27     42   
    })
          43  +
    /* ProtocolParserGenerator.kt:71 */
   28     44   
}
   29     45   
          46  +
/* JsonSerializerGenerator.kt:287 */
   30     47   
pub fn ser_json_maps_input(
   31     48   
    input: &crate::operation::json_maps::JsonMapsInput,
   32     49   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
          50  +
    /* JsonSerializerGenerator.kt:291 */
   33     51   
    let mut out = String::new();
          52  +
    /* JsonSerializerGenerator.kt:292 */
   34     53   
    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
          54  +
    /* JsonSerializerGenerator.kt:375 */
   35     55   
    crate::protocol_serde::shape_json_maps_input::ser_json_maps_input_input(&mut object, input)?;
          56  +
    /* JsonSerializerGenerator.kt:295 */
   36     57   
    object.finish();
          58  +
    /* JsonSerializerGenerator.kt:296 */
   37     59   
    Ok(::aws_smithy_types::body::SdkBody::from(out))
          60  +
    /* JsonSerializerGenerator.kt:287 */
   38     61   
}
   39     62   
          63  +
/* JsonParserGenerator.kt:148 */
   40     64   
pub(crate) fn de_json_maps(
   41     65   
    value: &[u8],
   42     66   
    mut builder: crate::operation::json_maps::builders::JsonMapsOutputBuilder,
   43     67   
) -> ::std::result::Result<crate::operation::json_maps::builders::JsonMapsOutputBuilder, ::aws_smithy_json::deserialize::error::DeserializeError> {
          68  +
    /* JsonParserGenerator.kt:153 */
   44     69   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
   45     70   
    let tokens = &mut tokens_owned;
   46     71   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
          72  +
    /* JsonParserGenerator.kt:684 */
   47     73   
    loop {
          74  +
        /* JsonParserGenerator.kt:685 */
   48     75   
        match tokens.next().transpose()? {
   49         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   50         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
   51         -
                "denseBooleanMap" => {
   52         -
                    builder = builder.set_dense_boolean_map(crate::protocol_serde::shape_dense_boolean_map::de_dense_boolean_map(tokens)?);
          76  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
          77  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
          78  +
                /* JsonParserGenerator.kt:260 */
          79  +
                match key.to_unescaped()?.as_ref() {
          80  +
                    /* JsonParserGenerator.kt:262 */
          81  +
                    "denseBooleanMap" => {
          82  +
                        /* JsonParserGenerator.kt:265 */
          83  +
                        builder = builder.set_dense_boolean_map(
          84  +
                            /* JsonParserGenerator.kt:509 */
          85  +
                            crate::protocol_serde::shape_dense_boolean_map::de_dense_boolean_map(tokens)?, /* JsonParserGenerator.kt:265 */
          86  +
                        );
          87  +
                        /* JsonParserGenerator.kt:262 */
          88  +
                    }
          89  +
                    /* JsonParserGenerator.kt:262 */
          90  +
                    "denseNumberMap" => {
          91  +
                        /* JsonParserGenerator.kt:265 */
          92  +
                        builder = builder.set_dense_number_map(
          93  +
                            /* JsonParserGenerator.kt:509 */
          94  +
                            crate::protocol_serde::shape_dense_number_map::de_dense_number_map(tokens)?, /* JsonParserGenerator.kt:265 */
          95  +
                        );
          96  +
                        /* JsonParserGenerator.kt:262 */
          97  +
                    }
          98  +
                    /* JsonParserGenerator.kt:262 */
          99  +
                    "denseSetMap" => {
         100  +
                        /* JsonParserGenerator.kt:265 */
         101  +
                        builder = builder.set_dense_set_map(
         102  +
                            /* JsonParserGenerator.kt:509 */
         103  +
                            crate::protocol_serde::shape_dense_set_map::de_dense_set_map(tokens)?, /* JsonParserGenerator.kt:265 */
         104  +
                        );
         105  +
                        /* JsonParserGenerator.kt:262 */
         106  +
                    }
         107  +
                    /* JsonParserGenerator.kt:262 */
         108  +
                    "denseStringMap" => {
         109  +
                        /* JsonParserGenerator.kt:265 */
         110  +
                        builder = builder.set_dense_string_map(
         111  +
                            /* JsonParserGenerator.kt:509 */
         112  +
                            crate::protocol_serde::shape_dense_string_map::de_dense_string_map(tokens)?, /* JsonParserGenerator.kt:265 */
         113  +
                        );
         114  +
                        /* JsonParserGenerator.kt:262 */
         115  +
                    }
         116  +
                    /* JsonParserGenerator.kt:262 */
         117  +
                    "denseStructMap" => {
         118  +
                        /* JsonParserGenerator.kt:265 */
         119  +
                        builder = builder.set_dense_struct_map(
         120  +
                            /* JsonParserGenerator.kt:509 */
         121  +
                            crate::protocol_serde::shape_dense_struct_map::de_dense_struct_map(tokens)?, /* JsonParserGenerator.kt:265 */
         122  +
                        );
         123  +
                        /* JsonParserGenerator.kt:262 */
         124  +
                    }
         125  +
                    /* JsonParserGenerator.kt:290 */
         126  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
   53    127   
                }
   54         -
                "denseNumberMap" => {
   55         -
                    builder = builder.set_dense_number_map(crate::protocol_serde::shape_dense_number_map::de_dense_number_map(tokens)?);
   56         -
                }
   57         -
                "denseSetMap" => {
   58         -
                    builder = builder.set_dense_set_map(crate::protocol_serde::shape_dense_set_map::de_dense_set_map(tokens)?);
   59         -
                }
   60         -
                "denseStringMap" => {
   61         -
                    builder = builder.set_dense_string_map(crate::protocol_serde::shape_dense_string_map::de_dense_string_map(tokens)?);
   62         -
                }
   63         -
                "denseStructMap" => {
   64         -
                    builder = builder.set_dense_struct_map(crate::protocol_serde::shape_dense_struct_map::de_dense_struct_map(tokens)?);
   65         -
                }
   66         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   67         -
            },
         128  +
                /* JsonParserGenerator.kt:686 */
         129  +
            }
         130  +
            /* JsonParserGenerator.kt:695 */
   68    131   
            other => {
   69    132   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   70    133   
                    "expected object key or end object, found: {:?}",
   71    134   
                    other
   72    135   
                )))
   73         -
            }
         136  +
            } /* JsonParserGenerator.kt:685 */
   74    137   
        }
         138  +
        /* JsonParserGenerator.kt:684 */
   75    139   
    }
         140  +
    /* JsonParserGenerator.kt:250 */
   76    141   
    if tokens.next().is_some() {
         142  +
        /* JsonParserGenerator.kt:251 */
   77    143   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   78    144   
            "found more JSON tokens after completing parsing",
   79    145   
        ));
         146  +
        /* JsonParserGenerator.kt:250 */
   80    147   
    }
         148  +
    /* JsonParserGenerator.kt:163 */
   81    149   
    Ok(builder)
         150  +
    /* JsonParserGenerator.kt:148 */
   82    151   
}

tmp-codegen-diff/codegen-client-test/rest_json/rust-client-codegen/src/protocol_serde/shape_json_maps_input.rs

@@ -1,1 +69,131 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_json_maps_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::json_maps::JsonMapsInput,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.dense_boolean_map {
           9  +
        /* JsonSerializerGenerator.kt:495 */
    7     10   
        #[allow(unused_mut)]
          11  +
        /* JsonSerializerGenerator.kt:496 */
    8     12   
        let mut object_2 = object.key("denseBooleanMap").start_object();
          13  +
        /* JsonSerializerGenerator.kt:537 */
    9     14   
        for (key_3, value_4) in var_1 {
          15  +
            /* SerializerUtil.kt:42 */
   10     16   
            {
          17  +
                /* JsonSerializerGenerator.kt:424 */
   11     18   
                object_2.key(key_3.as_str()).boolean(*value_4);
          19  +
                /* SerializerUtil.kt:42 */
   12     20   
            }
          21  +
            /* JsonSerializerGenerator.kt:537 */
   13     22   
        }
          23  +
        /* JsonSerializerGenerator.kt:515 */
   14     24   
        object_2.finish();
          25  +
        /* JsonSerializerGenerator.kt:382 */
   15     26   
    }
          27  +
    /* JsonSerializerGenerator.kt:382 */
   16     28   
    if let Some(var_5) = &input.dense_number_map {
          29  +
        /* JsonSerializerGenerator.kt:495 */
   17     30   
        #[allow(unused_mut)]
          31  +
        /* JsonSerializerGenerator.kt:496 */
   18     32   
        let mut object_6 = object.key("denseNumberMap").start_object();
          33  +
        /* JsonSerializerGenerator.kt:537 */
   19     34   
        for (key_7, value_8) in var_5 {
          35  +
            /* SerializerUtil.kt:42 */
   20     36   
            {
          37  +
                /* JsonSerializerGenerator.kt:432 */
   21     38   
                object_6.key(key_7.as_str()).number(
   22     39   
                    #[allow(clippy::useless_conversion)]
   23     40   
                    ::aws_smithy_types::Number::NegInt((*value_8).into()),
   24     41   
                );
          42  +
                /* SerializerUtil.kt:42 */
   25     43   
            }
          44  +
            /* JsonSerializerGenerator.kt:537 */
   26     45   
        }
          46  +
        /* JsonSerializerGenerator.kt:515 */
   27     47   
        object_6.finish();
          48  +
        /* JsonSerializerGenerator.kt:382 */
   28     49   
    }
          50  +
    /* JsonSerializerGenerator.kt:382 */
   29     51   
    if let Some(var_9) = &input.dense_set_map {
          52  +
        /* JsonSerializerGenerator.kt:495 */
   30     53   
        #[allow(unused_mut)]
          54  +
        /* JsonSerializerGenerator.kt:496 */
   31     55   
        let mut object_10 = object.key("denseSetMap").start_object();
          56  +
        /* JsonSerializerGenerator.kt:537 */
   32     57   
        for (key_11, value_12) in var_9 {
          58  +
            /* SerializerUtil.kt:42 */
   33     59   
            {
          60  +
                /* JsonSerializerGenerator.kt:484 */
   34     61   
                let mut array_13 = object_10.key(key_11.as_str()).start_array();
          62  +
                /* JsonSerializerGenerator.kt:524 */
   35     63   
                for item_14 in value_12 {
          64  +
                    /* SerializerUtil.kt:42 */
   36     65   
                    {
          66  +
                        /* JsonSerializerGenerator.kt:423 */
   37     67   
                        array_13.value().string(item_14.as_str());
          68  +
                        /* SerializerUtil.kt:42 */
   38     69   
                    }
          70  +
                    /* JsonSerializerGenerator.kt:524 */
   39     71   
                }
          72  +
                /* JsonSerializerGenerator.kt:486 */
   40     73   
                array_13.finish();
          74  +
                /* SerializerUtil.kt:42 */
   41     75   
            }
          76  +
            /* JsonSerializerGenerator.kt:537 */
   42     77   
        }
          78  +
        /* JsonSerializerGenerator.kt:515 */
   43     79   
        object_10.finish();
          80  +
        /* JsonSerializerGenerator.kt:382 */
   44     81   
    }
          82  +
    /* JsonSerializerGenerator.kt:382 */
   45     83   
    if let Some(var_15) = &input.dense_string_map {
          84  +
        /* JsonSerializerGenerator.kt:495 */
   46     85   
        #[allow(unused_mut)]
          86  +
        /* JsonSerializerGenerator.kt:496 */
   47     87   
        let mut object_16 = object.key("denseStringMap").start_object();
          88  +
        /* JsonSerializerGenerator.kt:537 */
   48     89   
        for (key_17, value_18) in var_15 {
          90  +
            /* SerializerUtil.kt:42 */
   49     91   
            {
          92  +
                /* JsonSerializerGenerator.kt:423 */
   50     93   
                object_16.key(key_17.as_str()).string(value_18.as_str());
          94  +
                /* SerializerUtil.kt:42 */
   51     95   
            }
          96  +
            /* JsonSerializerGenerator.kt:537 */
   52     97   
        }
          98  +
        /* JsonSerializerGenerator.kt:515 */
   53     99   
        object_16.finish();
         100  +
        /* JsonSerializerGenerator.kt:382 */
   54    101   
    }
         102  +
    /* JsonSerializerGenerator.kt:382 */
   55    103   
    if let Some(var_19) = &input.dense_struct_map {
         104  +
        /* JsonSerializerGenerator.kt:495 */
   56    105   
        #[allow(unused_mut)]
         106  +
        /* JsonSerializerGenerator.kt:496 */
   57    107   
        let mut object_20 = object.key("denseStructMap").start_object();
         108  +
        /* JsonSerializerGenerator.kt:537 */
   58    109   
        for (key_21, value_22) in var_19 {
         110  +
            /* SerializerUtil.kt:42 */
   59    111   
            {
         112  +
                /* JsonSerializerGenerator.kt:495 */
   60    113   
                #[allow(unused_mut)]
         114  +
                /* JsonSerializerGenerator.kt:496 */
   61    115   
                let mut object_23 = object_20.key(key_21.as_str()).start_object();
         116  +
                /* JsonSerializerGenerator.kt:375 */
   62    117   
                crate::protocol_serde::shape_greeting_struct::ser_greeting_struct(&mut object_23, value_22)?;
         118  +
                /* JsonSerializerGenerator.kt:515 */
   63    119   
                object_23.finish();
         120  +
                /* SerializerUtil.kt:42 */
   64    121   
            }
         122  +
            /* JsonSerializerGenerator.kt:537 */
   65    123   
        }
         124  +
        /* JsonSerializerGenerator.kt:515 */
   66    125   
        object_20.finish();
         126  +
        /* JsonSerializerGenerator.kt:382 */
   67    127   
    }
         128  +
    /* JsonSerializerGenerator.kt:372 */
   68    129   
    Ok(())
         130  +
    /* JsonSerializerGenerator.kt:358 */
   69    131   
}

tmp-codegen-diff/codegen-client-test/rest_json/rust-client-codegen/src/protocol_serde/shape_json_timestamps.rs

@@ -1,1 +112,193 @@
    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_json_timestamps_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::json_timestamps::JsonTimestampsOutput, crate::operation::json_timestamps::JsonTimestampsError> {
          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::json_timestamps::JsonTimestampsError::unhandled)?;
          15  +
    /* ProtocolParserGenerator.kt:120 */
   11     16   
    let generic = generic_builder.build();
          17  +
    /* ProtocolParserGenerator.kt:185 */
   12     18   
    Err(crate::operation::json_timestamps::JsonTimestampsError::generic(generic))
          19  +
    /* ProtocolParserGenerator.kt:99 */
   13     20   
}
   14     21   
          22  +
/* RustType.kt:516 */
   15     23   
#[allow(clippy::unnecessary_wraps)]
          24  +
/* ProtocolParserGenerator.kt:71 */
   16     25   
pub fn de_json_timestamps_http_response(
   17     26   
    _response_status: u16,
   18     27   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
   19     28   
    _response_body: &[u8],
   20     29   
) -> std::result::Result<crate::operation::json_timestamps::JsonTimestampsOutput, crate::operation::json_timestamps::JsonTimestampsError> {
          30  +
    /* ProtocolParserGenerator.kt:77 */
   21     31   
    Ok({
          32  +
        /* RustType.kt:516 */
   22     33   
        #[allow(unused_mut)]
          34  +
        /* ProtocolParserGenerator.kt:240 */
   23     35   
        let mut output = crate::operation::json_timestamps::builders::JsonTimestampsOutputBuilder::default();
          36  +
        /* ProtocolParserGenerator.kt:247 */
   24     37   
        output = crate::protocol_serde::shape_json_timestamps::de_json_timestamps(_response_body, output)
   25     38   
            .map_err(crate::operation::json_timestamps::JsonTimestampsError::unhandled)?;
          39  +
        /* ClientBuilderInstantiator.kt:56 */
   26     40   
        output.build()
          41  +
        /* ProtocolParserGenerator.kt:77 */
   27     42   
    })
          43  +
    /* ProtocolParserGenerator.kt:71 */
   28     44   
}
   29     45   
          46  +
/* JsonSerializerGenerator.kt:287 */
   30     47   
pub fn ser_json_timestamps_input(
   31     48   
    input: &crate::operation::json_timestamps::JsonTimestampsInput,
   32     49   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
          50  +
    /* JsonSerializerGenerator.kt:291 */
   33     51   
    let mut out = String::new();
          52  +
    /* JsonSerializerGenerator.kt:292 */
   34     53   
    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
          54  +
    /* JsonSerializerGenerator.kt:375 */
   35     55   
    crate::protocol_serde::shape_json_timestamps_input::ser_json_timestamps_input_input(&mut object, input)?;
          56  +
    /* JsonSerializerGenerator.kt:295 */
   36     57   
    object.finish();
          58  +
    /* JsonSerializerGenerator.kt:296 */
   37     59   
    Ok(::aws_smithy_types::body::SdkBody::from(out))
          60  +
    /* JsonSerializerGenerator.kt:287 */
   38     61   
}
   39     62   
          63  +
/* JsonParserGenerator.kt:148 */
   40     64   
pub(crate) fn de_json_timestamps(
   41     65   
    value: &[u8],
   42     66   
    mut builder: crate::operation::json_timestamps::builders::JsonTimestampsOutputBuilder,
   43     67   
) -> ::std::result::Result<
   44     68   
    crate::operation::json_timestamps::builders::JsonTimestampsOutputBuilder,
   45     69   
    ::aws_smithy_json::deserialize::error::DeserializeError,
   46     70   
> {
          71  +
    /* JsonParserGenerator.kt:153 */
   47     72   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
   48     73   
    let tokens = &mut tokens_owned;
   49     74   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
          75  +
    /* JsonParserGenerator.kt:684 */
   50     76   
    loop {
          77  +
        /* JsonParserGenerator.kt:685 */
   51     78   
        match tokens.next().transpose()? {
   52         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   53         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
   54         -
                "dateTime" => {
   55         -
                    builder = builder.set_date_time(::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
   56         -
                        tokens.next(),
   57         -
                        ::aws_smithy_types::date_time::Format::DateTimeWithOffset,
   58         -
                    )?);
          79  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
          80  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
          81  +
                /* JsonParserGenerator.kt:260 */
          82  +
                match key.to_unescaped()?.as_ref() {
          83  +
                    /* JsonParserGenerator.kt:262 */
          84  +
                    "dateTime" => {
          85  +
                        /* JsonParserGenerator.kt:265 */
          86  +
                        builder = builder.set_date_time(
          87  +
                            /* JsonParserGenerator.kt:384 */
          88  +
                            ::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
          89  +
                                tokens.next(),
          90  +
                                ::aws_smithy_types::date_time::Format::DateTimeWithOffset,
          91  +
                            )?, /* JsonParserGenerator.kt:265 */
          92  +
                        );
          93  +
                        /* JsonParserGenerator.kt:262 */
          94  +
                    }
          95  +
                    /* JsonParserGenerator.kt:262 */
          96  +
                    "dateTimeOnTarget" => {
          97  +
                        /* JsonParserGenerator.kt:265 */
          98  +
                        builder = builder.set_date_time_on_target(
          99  +
                            /* JsonParserGenerator.kt:384 */
         100  +
                            ::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
         101  +
                                tokens.next(),
         102  +
                                ::aws_smithy_types::date_time::Format::DateTimeWithOffset,
         103  +
                            )?, /* JsonParserGenerator.kt:265 */
         104  +
                        );
         105  +
                        /* JsonParserGenerator.kt:262 */
         106  +
                    }
         107  +
                    /* JsonParserGenerator.kt:262 */
         108  +
                    "epochSeconds" => {
         109  +
                        /* JsonParserGenerator.kt:265 */
         110  +
                        builder = builder.set_epoch_seconds(
         111  +
                            /* JsonParserGenerator.kt:384 */
         112  +
                            ::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
         113  +
                                tokens.next(),
         114  +
                                ::aws_smithy_types::date_time::Format::EpochSeconds,
         115  +
                            )?, /* JsonParserGenerator.kt:265 */
         116  +
                        );
         117  +
                        /* JsonParserGenerator.kt:262 */
         118  +
                    }
         119  +
                    /* JsonParserGenerator.kt:262 */
         120  +
                    "epochSecondsOnTarget" => {
         121  +
                        /* JsonParserGenerator.kt:265 */
         122  +
                        builder = builder.set_epoch_seconds_on_target(
         123  +
                            /* JsonParserGenerator.kt:384 */
         124  +
                            ::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
         125  +
                                tokens.next(),
         126  +
                                ::aws_smithy_types::date_time::Format::EpochSeconds,
         127  +
                            )?, /* JsonParserGenerator.kt:265 */
         128  +
                        );
         129  +
                        /* JsonParserGenerator.kt:262 */
         130  +
                    }
         131  +
                    /* JsonParserGenerator.kt:262 */
         132  +
                    "httpDate" => {
         133  +
                        /* JsonParserGenerator.kt:265 */
         134  +
                        builder = builder.set_http_date(
         135  +
                            /* JsonParserGenerator.kt:384 */
         136  +
                            ::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
         137  +
                                tokens.next(),
         138  +
                                ::aws_smithy_types::date_time::Format::HttpDate,
         139  +
                            )?, /* JsonParserGenerator.kt:265 */
         140  +
                        );
         141  +
                        /* JsonParserGenerator.kt:262 */
         142  +
                    }
         143  +
                    /* JsonParserGenerator.kt:262 */
         144  +
                    "httpDateOnTarget" => {
         145  +
                        /* JsonParserGenerator.kt:265 */
         146  +
                        builder = builder.set_http_date_on_target(
         147  +
                            /* JsonParserGenerator.kt:384 */
         148  +
                            ::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
         149  +
                                tokens.next(),
         150  +
                                ::aws_smithy_types::date_time::Format::HttpDate,
         151  +
                            )?, /* JsonParserGenerator.kt:265 */
         152  +
                        );
         153  +
                        /* JsonParserGenerator.kt:262 */
         154  +
                    }
         155  +
                    /* JsonParserGenerator.kt:262 */
         156  +
                    "normal" => {
         157  +
                        /* JsonParserGenerator.kt:265 */
         158  +
                        builder = builder.set_normal(
         159  +
                            /* JsonParserGenerator.kt:384 */
         160  +
                            ::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
         161  +
                                tokens.next(),
         162  +
                                ::aws_smithy_types::date_time::Format::EpochSeconds,
         163  +
                            )?, /* JsonParserGenerator.kt:265 */
         164  +
                        );
         165  +
                        /* JsonParserGenerator.kt:262 */
         166  +
                    }
         167  +
                    /* JsonParserGenerator.kt:290 */
         168  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
   59    169   
                }
   60         -
                "dateTimeOnTarget" => {
   61         -
                    builder = builder.set_date_time_on_target(::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
   62         -
                        tokens.next(),
   63         -
                        ::aws_smithy_types::date_time::Format::DateTimeWithOffset,
   64         -
                    )?);
   65         -
                }
   66         -
                "epochSeconds" => {
   67         -
                    builder = builder.set_epoch_seconds(::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
   68         -
                        tokens.next(),
   69         -
                        ::aws_smithy_types::date_time::Format::EpochSeconds,
   70         -
                    )?);
   71         -
                }
   72         -
                "epochSecondsOnTarget" => {
   73         -
                    builder = builder.set_epoch_seconds_on_target(::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
   74         -
                        tokens.next(),
   75         -
                        ::aws_smithy_types::date_time::Format::EpochSeconds,
   76         -
                    )?);
   77         -
                }
   78         -
                "httpDate" => {
   79         -
                    builder = builder.set_http_date(::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
   80         -
                        tokens.next(),
   81         -
                        ::aws_smithy_types::date_time::Format::HttpDate,
   82         -
                    )?);
   83         -
                }
   84         -
                "httpDateOnTarget" => {
   85         -
                    builder = builder.set_http_date_on_target(::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
   86         -
                        tokens.next(),
   87         -
                        ::aws_smithy_types::date_time::Format::HttpDate,
   88         -
                    )?);
   89         -
                }
   90         -
                "normal" => {
   91         -
                    builder = builder.set_normal(::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
   92         -
                        tokens.next(),
   93         -
                        ::aws_smithy_types::date_time::Format::EpochSeconds,
   94         -
                    )?);
   95         -
                }
   96         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   97         -
            },
         170  +
                /* JsonParserGenerator.kt:686 */
         171  +
            }
         172  +
            /* JsonParserGenerator.kt:695 */
   98    173   
            other => {
   99    174   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
  100    175   
                    "expected object key or end object, found: {:?}",
  101    176   
                    other
  102    177   
                )))
  103         -
            }
         178  +
            } /* JsonParserGenerator.kt:685 */
  104    179   
        }
         180  +
        /* JsonParserGenerator.kt:684 */
  105    181   
    }
         182  +
    /* JsonParserGenerator.kt:250 */
  106    183   
    if tokens.next().is_some() {
         184  +
        /* JsonParserGenerator.kt:251 */
  107    185   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
  108    186   
            "found more JSON tokens after completing parsing",
  109    187   
        ));
         188  +
        /* JsonParserGenerator.kt:250 */
  110    189   
    }
         190  +
    /* JsonParserGenerator.kt:163 */
  111    191   
    Ok(builder)
         192  +
    /* JsonParserGenerator.kt:148 */
  112    193   
}

tmp-codegen-diff/codegen-client-test/rest_json/rust-client-codegen/src/protocol_serde/shape_json_timestamps_input.rs

@@ -1,1 +38,62 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_json_timestamps_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::json_timestamps::JsonTimestampsInput,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.date_time {
           9  +
        /* JsonSerializerGenerator.kt:448 */
    7     10   
        object.key("dateTime").date_time(var_1, ::aws_smithy_types::date_time::Format::DateTime)?;
          11  +
        /* JsonSerializerGenerator.kt:382 */
    8     12   
    }
          13  +
    /* JsonSerializerGenerator.kt:382 */
    9     14   
    if let Some(var_2) = &input.date_time_on_target {
          15  +
        /* JsonSerializerGenerator.kt:448 */
   10     16   
        object
   11     17   
            .key("dateTimeOnTarget")
   12     18   
            .date_time(var_2, ::aws_smithy_types::date_time::Format::DateTime)?;
          19  +
        /* JsonSerializerGenerator.kt:382 */
   13     20   
    }
          21  +
    /* JsonSerializerGenerator.kt:382 */
   14     22   
    if let Some(var_3) = &input.epoch_seconds {
          23  +
        /* JsonSerializerGenerator.kt:448 */
   15     24   
        object
   16     25   
            .key("epochSeconds")
   17     26   
            .date_time(var_3, ::aws_smithy_types::date_time::Format::EpochSeconds)?;
          27  +
        /* JsonSerializerGenerator.kt:382 */
   18     28   
    }
          29  +
    /* JsonSerializerGenerator.kt:382 */
   19     30   
    if let Some(var_4) = &input.epoch_seconds_on_target {
          31  +
        /* JsonSerializerGenerator.kt:448 */
   20     32   
        object
   21     33   
            .key("epochSecondsOnTarget")
   22     34   
            .date_time(var_4, ::aws_smithy_types::date_time::Format::EpochSeconds)?;
          35  +
        /* JsonSerializerGenerator.kt:382 */
   23     36   
    }
          37  +
    /* JsonSerializerGenerator.kt:382 */
   24     38   
    if let Some(var_5) = &input.http_date {
          39  +
        /* JsonSerializerGenerator.kt:448 */
   25     40   
        object.key("httpDate").date_time(var_5, ::aws_smithy_types::date_time::Format::HttpDate)?;
          41  +
        /* JsonSerializerGenerator.kt:382 */
   26     42   
    }
          43  +
    /* JsonSerializerGenerator.kt:382 */
   27     44   
    if let Some(var_6) = &input.http_date_on_target {
          45  +
        /* JsonSerializerGenerator.kt:448 */
   28     46   
        object
   29     47   
            .key("httpDateOnTarget")
   30     48   
            .date_time(var_6, ::aws_smithy_types::date_time::Format::HttpDate)?;
          49  +
        /* JsonSerializerGenerator.kt:382 */
   31     50   
    }
          51  +
    /* JsonSerializerGenerator.kt:382 */
   32     52   
    if let Some(var_7) = &input.normal {
          53  +
        /* JsonSerializerGenerator.kt:448 */
   33     54   
        object
   34     55   
            .key("normal")
   35     56   
            .date_time(var_7, ::aws_smithy_types::date_time::Format::EpochSeconds)?;
          57  +
        /* JsonSerializerGenerator.kt:382 */
   36     58   
    }
          59  +
    /* JsonSerializerGenerator.kt:372 */
   37     60   
    Ok(())
          61  +
    /* JsonSerializerGenerator.kt:358 */
   38     62   
}

tmp-codegen-diff/codegen-client-test/rest_json/rust-client-codegen/src/protocol_serde/shape_json_unions.rs

@@ -1,1 +71,116 @@
    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_json_unions_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::json_unions::JsonUnionsOutput, crate::operation::json_unions::JsonUnionsError> {
          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::json_unions::JsonUnionsError::unhandled)?;
          15  +
    /* ProtocolParserGenerator.kt:120 */
   11     16   
    let generic = generic_builder.build();
          17  +
    /* ProtocolParserGenerator.kt:185 */
   12     18   
    Err(crate::operation::json_unions::JsonUnionsError::generic(generic))
          19  +
    /* ProtocolParserGenerator.kt:99 */
   13     20   
}
   14     21   
          22  +
/* RustType.kt:516 */
   15     23   
#[allow(clippy::unnecessary_wraps)]
          24  +
/* ProtocolParserGenerator.kt:71 */
   16     25   
pub fn de_json_unions_http_response(
   17     26   
    _response_status: u16,
   18     27   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
   19     28   
    _response_body: &[u8],
   20     29   
) -> std::result::Result<crate::operation::json_unions::JsonUnionsOutput, crate::operation::json_unions::JsonUnionsError> {
          30  +
    /* ProtocolParserGenerator.kt:77 */
   21     31   
    Ok({
          32  +
        /* RustType.kt:516 */
   22     33   
        #[allow(unused_mut)]
          34  +
        /* ProtocolParserGenerator.kt:240 */
   23     35   
        let mut output = crate::operation::json_unions::builders::JsonUnionsOutputBuilder::default();
          36  +
        /* ProtocolParserGenerator.kt:247 */
   24     37   
        output = crate::protocol_serde::shape_json_unions::de_json_unions(_response_body, output)
   25     38   
            .map_err(crate::operation::json_unions::JsonUnionsError::unhandled)?;
          39  +
        /* ClientBuilderInstantiator.kt:56 */
   26     40   
        output.build()
          41  +
        /* ProtocolParserGenerator.kt:77 */
   27     42   
    })
          43  +
    /* ProtocolParserGenerator.kt:71 */
   28     44   
}
   29     45   
          46  +
/* JsonSerializerGenerator.kt:287 */
   30     47   
pub fn ser_json_unions_input(
   31     48   
    input: &crate::operation::json_unions::JsonUnionsInput,
   32     49   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
          50  +
    /* JsonSerializerGenerator.kt:291 */
   33     51   
    let mut out = String::new();
          52  +
    /* JsonSerializerGenerator.kt:292 */
   34     53   
    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
          54  +
    /* JsonSerializerGenerator.kt:375 */
   35     55   
    crate::protocol_serde::shape_json_unions_input::ser_json_unions_input_input(&mut object, input)?;
          56  +
    /* JsonSerializerGenerator.kt:295 */
   36     57   
    object.finish();
          58  +
    /* JsonSerializerGenerator.kt:296 */
   37     59   
    Ok(::aws_smithy_types::body::SdkBody::from(out))
          60  +
    /* JsonSerializerGenerator.kt:287 */
   38     61   
}
   39     62   
          63  +
/* JsonParserGenerator.kt:148 */
   40     64   
pub(crate) fn de_json_unions(
   41     65   
    value: &[u8],
   42     66   
    mut builder: crate::operation::json_unions::builders::JsonUnionsOutputBuilder,
   43     67   
) -> ::std::result::Result<crate::operation::json_unions::builders::JsonUnionsOutputBuilder, ::aws_smithy_json::deserialize::error::DeserializeError>
   44     68   
{
          69  +
    /* JsonParserGenerator.kt:153 */
   45     70   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
   46     71   
    let tokens = &mut tokens_owned;
   47     72   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
          73  +
    /* JsonParserGenerator.kt:684 */
   48     74   
    loop {
          75  +
        /* JsonParserGenerator.kt:685 */
   49     76   
        match tokens.next().transpose()? {
   50         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   51         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
   52         -
                "contents" => {
   53         -
                    builder = builder.set_contents(crate::protocol_serde::shape_my_union::de_my_union(tokens)?);
          77  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
          78  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
          79  +
                /* JsonParserGenerator.kt:260 */
          80  +
                match key.to_unescaped()?.as_ref() {
          81  +
                    /* JsonParserGenerator.kt:262 */
          82  +
                    "contents" => {
          83  +
                        /* JsonParserGenerator.kt:265 */
          84  +
                        builder = builder.set_contents(
          85  +
                            /* JsonParserGenerator.kt:660 */
          86  +
                            crate::protocol_serde::shape_my_union::de_my_union(tokens)?, /* JsonParserGenerator.kt:265 */
          87  +
                        );
          88  +
                        /* JsonParserGenerator.kt:262 */
          89  +
                    }
          90  +
                    /* JsonParserGenerator.kt:290 */
          91  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
   54     92   
                }
   55         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   56         -
            },
          93  +
                /* JsonParserGenerator.kt:686 */
          94  +
            }
          95  +
            /* JsonParserGenerator.kt:695 */
   57     96   
            other => {
   58     97   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   59     98   
                    "expected object key or end object, found: {:?}",
   60     99   
                    other
   61    100   
                )))
   62         -
            }
         101  +
            } /* JsonParserGenerator.kt:685 */
   63    102   
        }
         103  +
        /* JsonParserGenerator.kt:684 */
   64    104   
    }
         105  +
    /* JsonParserGenerator.kt:250 */
   65    106   
    if tokens.next().is_some() {
         107  +
        /* JsonParserGenerator.kt:251 */
   66    108   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   67    109   
            "found more JSON tokens after completing parsing",
   68    110   
        ));
         111  +
        /* JsonParserGenerator.kt:250 */
   69    112   
    }
         113  +
    /* JsonParserGenerator.kt:163 */
   70    114   
    Ok(builder)
         115  +
    /* JsonParserGenerator.kt:148 */
   71    116   
}

tmp-codegen-diff/codegen-client-test/rest_json/rust-client-codegen/src/protocol_serde/shape_json_unions_input.rs

@@ -1,1 +13,22 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* JsonSerializerGenerator.kt:358 */
    2      3   
pub fn ser_json_unions_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::json_unions::JsonUnionsInput,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.contents {
           9  +
        /* JsonSerializerGenerator.kt:495 */
    7     10   
        #[allow(unused_mut)]
          11  +
        /* JsonSerializerGenerator.kt:496 */
    8     12   
        let mut object_2 = object.key("contents").start_object();
          13  +
        /* JsonSerializerGenerator.kt:579 */
    9     14   
        crate::protocol_serde::shape_my_union::ser_my_union(&mut object_2, var_1)?;
          15  +
        /* JsonSerializerGenerator.kt:515 */
   10     16   
        object_2.finish();
          17  +
        /* JsonSerializerGenerator.kt:382 */
   11     18   
    }
          19  +
    /* JsonSerializerGenerator.kt:372 */
   12     20   
    Ok(())
          21  +
    /* JsonSerializerGenerator.kt:358 */
   13     22   
}

tmp-codegen-diff/codegen-client-test/rest_json/rust-client-codegen/src/protocol_serde/shape_malformed_accept_with_body.rs

@@ -1,1 +75,114 @@
    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_malformed_accept_with_body_http_error(
    4      6   
    _response_status: u16,
    5      7   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
    6      8   
    _response_body: &[u8],
    7      9   
) -> std::result::Result<
    8     10   
    crate::operation::malformed_accept_with_body::MalformedAcceptWithBodyOutput,
    9     11   
    crate::operation::malformed_accept_with_body::MalformedAcceptWithBodyError,
   10     12   
> {
          13  +
    /* RustType.kt:516 */
   11     14   
    #[allow(unused_mut)]
          15  +
    /* ProtocolParserGenerator.kt:106 */
   12     16   
    let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(_response_status, _response_headers, _response_body)
   13     17   
        .map_err(crate::operation::malformed_accept_with_body::MalformedAcceptWithBodyError::unhandled)?;
          18  +
    /* ProtocolParserGenerator.kt:120 */
   14     19   
    let generic = generic_builder.build();
          20  +
    /* ProtocolParserGenerator.kt:185 */
   15     21   
    Err(crate::operation::malformed_accept_with_body::MalformedAcceptWithBodyError::generic(
   16     22   
        generic,
   17     23   
    ))
          24  +
    /* ProtocolParserGenerator.kt:99 */
   18     25   
}
   19     26   
          27  +
/* RustType.kt:516 */
   20     28   
#[allow(clippy::unnecessary_wraps)]
          29  +
/* ProtocolParserGenerator.kt:71 */
   21     30   
pub fn de_malformed_accept_with_body_http_response(
   22     31   
    _response_status: u16,
   23     32   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
   24     33   
    _response_body: &[u8],
   25     34   
) -> std::result::Result<
   26     35   
    crate::operation::malformed_accept_with_body::MalformedAcceptWithBodyOutput,
   27     36   
    crate::operation::malformed_accept_with_body::MalformedAcceptWithBodyError,
   28     37   
> {
          38  +
    /* ProtocolParserGenerator.kt:77 */
   29     39   
    Ok({
          40  +
        /* RustType.kt:516 */
   30     41   
        #[allow(unused_mut)]
          42  +
        /* ProtocolParserGenerator.kt:240 */
   31     43   
        let mut output = crate::operation::malformed_accept_with_body::builders::MalformedAcceptWithBodyOutputBuilder::default();
          44  +
        /* ProtocolParserGenerator.kt:247 */
   32     45   
        output = crate::protocol_serde::shape_malformed_accept_with_body::de_malformed_accept_with_body(_response_body, output)
   33     46   
            .map_err(crate::operation::malformed_accept_with_body::MalformedAcceptWithBodyError::unhandled)?;
          47  +
        /* ClientBuilderInstantiator.kt:56 */
   34     48   
        output.build()
          49  +
        /* ProtocolParserGenerator.kt:77 */
   35     50   
    })
          51  +
    /* ProtocolParserGenerator.kt:71 */
   36     52   
}
   37     53   
          54  +
/* JsonParserGenerator.kt:148 */
   38     55   
pub(crate) fn de_malformed_accept_with_body(
   39     56   
    value: &[u8],
   40     57   
    mut builder: crate::operation::malformed_accept_with_body::builders::MalformedAcceptWithBodyOutputBuilder,
   41     58   
) -> ::std::result::Result<
   42     59   
    crate::operation::malformed_accept_with_body::builders::MalformedAcceptWithBodyOutputBuilder,
   43     60   
    ::aws_smithy_json::deserialize::error::DeserializeError,
   44     61   
> {
          62  +
    /* JsonParserGenerator.kt:153 */
   45     63   
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(value)).peekable();
   46     64   
    let tokens = &mut tokens_owned;
   47     65   
    ::aws_smithy_json::deserialize::token::expect_start_object(tokens.next())?;
          66  +
    /* JsonParserGenerator.kt:684 */
   48     67   
    loop {
          68  +
        /* JsonParserGenerator.kt:685 */
   49     69   
        match tokens.next().transpose()? {
   50         -
            Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   51         -
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
   52         -
                "hi" => {
   53         -
                    builder = builder.set_hi(
   54         -
                        ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   55         -
                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   56         -
                            .transpose()?,
   57         -
                    );
          70  +
            /* JsonParserGenerator.kt:686 */ Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
          71  +
            Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
          72  +
                /* JsonParserGenerator.kt:260 */
          73  +
                match key.to_unescaped()?.as_ref() {
          74  +
                    /* JsonParserGenerator.kt:262 */
          75  +
                    "hi" => {
          76  +
                        /* JsonParserGenerator.kt:265 */
          77  +
                        builder = builder.set_hi(
          78  +
                            /* JsonParserGenerator.kt:354 */
          79  +
                            ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
          80  +
                                .map(|s|
          81  +
                                /* JsonParserGenerator.kt:339 */s.to_unescaped().map(|u|
          82  +
                                    /* JsonParserGenerator.kt:348 */u.into_owned()
          83  +
                                /* JsonParserGenerator.kt:339 */) /* JsonParserGenerator.kt:354 */)
          84  +
                                .transpose()?, /* JsonParserGenerator.kt:265 */
          85  +
                        );
          86  +
                        /* JsonParserGenerator.kt:262 */
          87  +
                    }
          88  +
                    /* JsonParserGenerator.kt:290 */
          89  +
                    _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?, /* JsonParserGenerator.kt:260 */
   58     90   
                }
   59         -
                _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
   60         -
            },
          91  +
                /* JsonParserGenerator.kt:686 */
          92  +
            }
          93  +
            /* JsonParserGenerator.kt:695 */
   61     94   
            other => {
   62     95   
                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   63     96   
                    "expected object key or end object, found: {:?}",
   64     97   
                    other
   65     98   
                )))
   66         -
            }
          99  +
            } /* JsonParserGenerator.kt:685 */
   67    100   
        }
         101  +
        /* JsonParserGenerator.kt:684 */
   68    102   
    }
         103  +
    /* JsonParserGenerator.kt:250 */
   69    104   
    if tokens.next().is_some() {
         105  +
        /* JsonParserGenerator.kt:251 */
   70    106   
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   71    107   
            "found more JSON tokens after completing parsing",
   72    108   
        ));
         109  +
        /* JsonParserGenerator.kt:250 */
   73    110   
    }
         111  +
    /* JsonParserGenerator.kt:163 */
   74    112   
    Ok(builder)
         113  +
    /* JsonParserGenerator.kt:148 */
   75    114   
}

tmp-codegen-diff/codegen-client-test/rest_json/rust-client-codegen/src/protocol_serde/shape_malformed_accept_with_generic_string.rs

@@ -1,1 +33,51 @@
    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_malformed_accept_with_generic_string_http_error(
    4      6   
    _response_status: u16,
    5      7   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
    6      8   
    _response_body: &[u8],
    7      9   
) -> std::result::Result<
    8     10   
    crate::operation::malformed_accept_with_generic_string::MalformedAcceptWithGenericStringOutput,
    9     11   
    crate::operation::malformed_accept_with_generic_string::MalformedAcceptWithGenericStringError,
   10     12   
> {
          13  +
    /* RustType.kt:516 */
   11     14   
    #[allow(unused_mut)]
          15  +
    /* ProtocolParserGenerator.kt:106 */
   12     16   
    let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(_response_status, _response_headers, _response_body)
   13     17   
        .map_err(crate::operation::malformed_accept_with_generic_string::MalformedAcceptWithGenericStringError::unhandled)?;
          18  +
    /* ProtocolParserGenerator.kt:120 */
   14     19   
    let generic = generic_builder.build();
          20  +
    /* ProtocolParserGenerator.kt:185 */
   15     21   
    Err(crate::operation::malformed_accept_with_generic_string::MalformedAcceptWithGenericStringError::generic(generic))
          22  +
    /* ProtocolParserGenerator.kt:99 */
   16     23   
}
   17     24   
          25  +
/* RustType.kt:516 */
   18     26   
#[allow(clippy::unnecessary_wraps)]
          27  +
/* ProtocolParserGenerator.kt:71 */
   19     28   
pub fn de_malformed_accept_with_generic_string_http_response(
   20     29   
    _response_status: u16,
   21     30   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
   22     31   
    _response_body: &[u8],
   23     32   
) -> std::result::Result<
   24     33   
    crate::operation::malformed_accept_with_generic_string::MalformedAcceptWithGenericStringOutput,
   25     34   
    crate::operation::malformed_accept_with_generic_string::MalformedAcceptWithGenericStringError,
   26     35   
> {
          36  +
    /* ProtocolParserGenerator.kt:77 */
   27     37   
    Ok({
          38  +
        /* RustType.kt:516 */
   28     39   
        #[allow(unused_mut)]
          40  +
        /* ProtocolParserGenerator.kt:240 */
   29     41   
        let mut output = crate::operation::malformed_accept_with_generic_string::builders::MalformedAcceptWithGenericStringOutputBuilder::default();
   30         -
        output = output.set_payload(crate::protocol_serde::shape_malformed_accept_with_generic_string_output::de_payload_payload(_response_body)?);
          42  +
        /* ProtocolParserGenerator.kt:267 */
          43  +
        output = output.set_payload(
          44  +
            /* ProtocolParserGenerator.kt:327 */crate::protocol_serde::shape_malformed_accept_with_generic_string_output::de_payload_payload(_response_body)?
          45  +
        /* ProtocolParserGenerator.kt:267 */);
          46  +
        /* ClientBuilderInstantiator.kt:56 */
   31     47   
        output.build()
          48  +
        /* ProtocolParserGenerator.kt:77 */
   32     49   
    })
          50  +
    /* ProtocolParserGenerator.kt:71 */
   33     51   
}

tmp-codegen-diff/codegen-client-test/rest_json/rust-client-codegen/src/protocol_serde/shape_malformed_accept_with_generic_string_output.rs

@@ -1,1 +15,21 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* HttpBindingGenerator.kt:248 */
    2      3   
pub(crate) fn de_payload_payload(
    3      4   
    body: &[u8],
    4      5   
) -> std::result::Result<
    5      6   
    ::std::option::Option<::std::string::String>,
    6      7   
    crate::operation::malformed_accept_with_generic_string::MalformedAcceptWithGenericStringError,
    7      8   
> {
           9  +
    /* HttpBindingGenerator.kt:319 */
    8     10   
    (!body.is_empty())
    9     11   
        .then(|| {
          12  +
            /* HttpBindingGenerator.kt:325 */
   10     13   
            let body_str = std::str::from_utf8(body)
   11     14   
                .map_err(crate::operation::malformed_accept_with_generic_string::MalformedAcceptWithGenericStringError::unhandled)?;
          15  +
            /* HttpBindingGenerator.kt:344 */
   12     16   
            Ok(body_str.to_string())
          17  +
            /* HttpBindingGenerator.kt:319 */
   13     18   
        })
   14     19   
        .transpose()
          20  +
    /* HttpBindingGenerator.kt:248 */
   15     21   
}

tmp-codegen-diff/codegen-client-test/rest_json/rust-client-codegen/src/protocol_serde/shape_malformed_accept_with_payload.rs

@@ -1,1 +37,53 @@
    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_malformed_accept_with_payload_http_error(
    4      6   
    _response_status: u16,
    5      7   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
    6      8   
    _response_body: &[u8],
    7      9   
) -> std::result::Result<
    8     10   
    crate::operation::malformed_accept_with_payload::MalformedAcceptWithPayloadOutput,
    9     11   
    crate::operation::malformed_accept_with_payload::MalformedAcceptWithPayloadError,
   10     12   
> {
          13  +
    /* RustType.kt:516 */
   11     14   
    #[allow(unused_mut)]
          15  +
    /* ProtocolParserGenerator.kt:106 */
   12     16   
    let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(_response_status, _response_headers, _response_body)
   13     17   
        .map_err(crate::operation::malformed_accept_with_payload::MalformedAcceptWithPayloadError::unhandled)?;
          18  +
    /* ProtocolParserGenerator.kt:120 */
   14     19   
    let generic = generic_builder.build();
          20  +
    /* ProtocolParserGenerator.kt:185 */
   15     21   
    Err(crate::operation::malformed_accept_with_payload::MalformedAcceptWithPayloadError::generic(
   16     22   
        generic,
   17     23   
    ))
          24  +
    /* ProtocolParserGenerator.kt:99 */
   18     25   
}
   19     26   
          27  +
/* RustType.kt:516 */
   20     28   
#[allow(clippy::unnecessary_wraps)]
          29  +
/* ProtocolParserGenerator.kt:71 */
   21     30   
pub fn de_malformed_accept_with_payload_http_response(
   22     31   
    _response_status: u16,
   23     32   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
   24     33   
    _response_body: &[u8],
   25     34   
) -> std::result::Result<
   26     35   
    crate::operation::malformed_accept_with_payload::MalformedAcceptWithPayloadOutput,
   27     36   
    crate::operation::malformed_accept_with_payload::MalformedAcceptWithPayloadError,
   28     37   
> {
          38  +
    /* ProtocolParserGenerator.kt:77 */
   29     39   
    Ok({
          40  +
        /* RustType.kt:516 */
   30     41   
        #[allow(unused_mut)]
          42  +
        /* ProtocolParserGenerator.kt:240 */
   31     43   
        let mut output = crate::operation::malformed_accept_with_payload::builders::MalformedAcceptWithPayloadOutputBuilder::default();
   32         -
        output = output.set_payload(crate::protocol_serde::shape_malformed_accept_with_payload_output::de_payload_payload(
   33         -
            _response_body,
   34         -
        )?);
          44  +
        /* ProtocolParserGenerator.kt:267 */
          45  +
        output = output.set_payload(
          46  +
            /* ProtocolParserGenerator.kt:327 */crate::protocol_serde::shape_malformed_accept_with_payload_output::de_payload_payload(_response_body)?
          47  +
        /* ProtocolParserGenerator.kt:267 */);
          48  +
        /* ClientBuilderInstantiator.kt:56 */
   35     49   
        output.build()
          50  +
        /* ProtocolParserGenerator.kt:77 */
   36     51   
    })
          52  +
    /* ProtocolParserGenerator.kt:71 */
   37     53   
}

tmp-codegen-diff/codegen-client-test/rest_json/rust-client-codegen/src/protocol_serde/shape_malformed_accept_with_payload_output.rs

@@ -1,1 +9,18 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
           2  +
/* HttpBindingGenerator.kt:248 */
    2      3   
pub(crate) fn de_payload_payload(
    3      4   
    body: &[u8],
    4      5   
) -> std::result::Result<
    5      6   
    ::std::option::Option<::aws_smithy_types::Blob>,
    6      7   
    crate::operation::malformed_accept_with_payload::MalformedAcceptWithPayloadError,
    7      8   
> {
    8         -
    (!body.is_empty()).then(|| Ok(::aws_smithy_types::Blob::new(body))).transpose()
           9  +
    /* HttpBindingGenerator.kt:319 */
          10  +
    (!body.is_empty())
          11  +
        .then(|| {
          12  +
            /* HttpBindingGenerator.kt:349 */
          13  +
            Ok(::aws_smithy_types::Blob::new(body))
          14  +
            /* HttpBindingGenerator.kt:319 */
          15  +
        })
          16  +
        .transpose()
          17  +
    /* HttpBindingGenerator.kt:248 */
    9     18   
}

tmp-codegen-diff/codegen-client-test/rest_json/rust-client-codegen/src/protocol_serde/shape_malformed_blob.rs

@@ -1,1 +36,58 @@
    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_malformed_blob_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::malformed_blob::MalformedBlobOutput, crate::operation::malformed_blob::MalformedBlobError> {
          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::malformed_blob::MalformedBlobError::unhandled)?;
          15  +
    /* ProtocolParserGenerator.kt:120 */
   11     16   
    let generic = generic_builder.build();
          17  +
    /* ProtocolParserGenerator.kt:185 */
   12     18   
    Err(crate::operation::malformed_blob::MalformedBlobError::generic(generic))
          19  +
    /* ProtocolParserGenerator.kt:99 */
   13     20   
}
   14     21   
          22  +
/* RustType.kt:516 */
   15     23   
#[allow(clippy::unnecessary_wraps)]
          24  +
/* ProtocolParserGenerator.kt:71 */
   16     25   
pub fn de_malformed_blob_http_response(
   17     26   
    _response_status: u16,
   18     27   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
   19     28   
    _response_body: &[u8],
   20     29   
) -> std::result::Result<crate::operation::malformed_blob::MalformedBlobOutput, crate::operation::malformed_blob::MalformedBlobError> {
          30  +
    /* ProtocolParserGenerator.kt:77 */
   21     31   
    Ok({
          32  +
        /* RustType.kt:516 */
   22     33   
        #[allow(unused_mut)]
          34  +
        /* ProtocolParserGenerator.kt:240 */
   23     35   
        let mut output = crate::operation::malformed_blob::builders::MalformedBlobOutputBuilder::default();
          36  +
        /* ClientBuilderInstantiator.kt:56 */
   24     37   
        output.build()
          38  +
        /* ProtocolParserGenerator.kt:77 */
   25     39   
    })
          40  +
    /* ProtocolParserGenerator.kt:71 */
   26     41   
}
   27     42   
          43  +
/* JsonSerializerGenerator.kt:287 */
   28     44   
pub fn ser_malformed_blob_input(
   29     45   
    input: &crate::operation::malformed_blob::MalformedBlobInput,
   30     46   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
          47  +
    /* JsonSerializerGenerator.kt:291 */
   31     48   
    let mut out = String::new();
          49  +
    /* JsonSerializerGenerator.kt:292 */
   32     50   
    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
          51  +
    /* JsonSerializerGenerator.kt:375 */
   33     52   
    crate::protocol_serde::shape_malformed_blob_input::ser_malformed_blob_input_input(&mut object, input)?;
          53  +
    /* JsonSerializerGenerator.kt:295 */
   34     54   
    object.finish();
          55  +
    /* JsonSerializerGenerator.kt:296 */
   35     56   
    Ok(::aws_smithy_types::body::SdkBody::from(out))
          57  +
    /* JsonSerializerGenerator.kt:287 */
   36     58   
}

tmp-codegen-diff/codegen-client-test/rest_json/rust-client-codegen/src/protocol_serde/shape_malformed_blob_input.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_malformed_blob_input_input(
    3      4   
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4      5   
    input: &crate::operation::malformed_blob::MalformedBlobInput,
    5      6   
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
           7  +
    /* JsonSerializerGenerator.kt:382 */
    6      8   
    if let Some(var_1) = &input.blob {
           9  +
        /* JsonSerializerGenerator.kt:439 */
    7     10   
        object.key("blob").string_unchecked(&::aws_smithy_types::base64::encode(var_1));
          11  +
        /* JsonSerializerGenerator.kt:382 */
    8     12   
    }
          13  +
    /* JsonSerializerGenerator.kt:372 */
    9     14   
    Ok(())
          15  +
    /* JsonSerializerGenerator.kt:358 */
   10     16   
}

tmp-codegen-diff/codegen-client-test/rest_json/rust-client-codegen/src/protocol_serde/shape_malformed_boolean.rs

@@ -1,1 +55,85 @@
    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_malformed_boolean_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::malformed_boolean::MalformedBooleanOutput, crate::operation::malformed_boolean::MalformedBooleanError> {
          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::malformed_boolean::MalformedBooleanError::unhandled)?;
          15  +
    /* ProtocolParserGenerator.kt:120 */
   11     16   
    let generic = generic_builder.build();
          17  +
    /* ProtocolParserGenerator.kt:185 */
   12     18   
    Err(crate::operation::malformed_boolean::MalformedBooleanError::generic(generic))
          19  +
    /* ProtocolParserGenerator.kt:99 */
   13     20   
}
   14     21   
          22  +
/* RustType.kt:516 */
   15     23   
#[allow(clippy::unnecessary_wraps)]
          24  +
/* ProtocolParserGenerator.kt:71 */
   16     25   
pub fn de_malformed_boolean_http_response(
   17     26   
    _response_status: u16,
   18     27   
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
   19     28   
    _response_body: &[u8],
   20     29   
) -> std::result::Result<crate::operation::malformed_boolean::MalformedBooleanOutput, crate::operation::malformed_boolean::MalformedBooleanError> {
          30  +
    /* ProtocolParserGenerator.kt:77 */
   21     31   
    Ok({
          32  +
        /* RustType.kt:516 */
   22     33   
        #[allow(unused_mut)]
          34  +
        /* ProtocolParserGenerator.kt:240 */
   23     35   
        let mut output = crate::operation::malformed_boolean::builders::MalformedBooleanOutputBuilder::default();
          36  +
        /* ClientBuilderInstantiator.kt:56 */
   24     37   
        output.build()
          38  +
        /* ProtocolParserGenerator.kt:77 */
   25     39   
    })
          40  +
    /* ProtocolParserGenerator.kt:71 */
   26     41   
}
   27     42   
          43  +
/* HttpBindingGenerator.kt:542 */
   28     44   
pub fn ser_malformed_boolean_headers(
   29     45   
    input: &crate::operation::malformed_boolean::MalformedBooleanInput,
   30     46   
    mut builder: ::http::request::Builder,
   31     47   
) -> std::result::Result<::http::request::Builder, ::aws_smithy_types::error::operation::BuildError> {
          48  +
    /* HttpBindingGenerator.kt:592 */
   32     49   
    if let ::std::option::Option::Some(inner_1) = &input.boolean_in_header {
          50  +
        /* HttpBindingGenerator.kt:690 */
   33     51   
        let mut encoder = ::aws_smithy_types::primitive::Encoder::from(*inner_1);
          52  +
        /* HttpBindingGenerator.kt:704 */
   34     53   
        let formatted_2 = encoder.encode();
          54  +
        /* HttpBindingGenerator.kt:706 */
   35     55   
        let header_value = formatted_2;
   36     56   
        let header_value: ::http::HeaderValue = header_value.parse().map_err(|err| {
   37     57   
            ::aws_smithy_types::error::operation::BuildError::invalid_field(
   38     58   
                "boolean_in_header",
   39     59   
                format!("`{}` cannot be used as a header value: {}", &header_value, err),
   40     60   
            )
   41     61   
        })?;
   42     62   
        builder = builder.header("booleanInHeader", header_value);
          63  +
        /* HttpBindingGenerator.kt:592 */
   43     64   
    }
          65  +
    /* HttpBindingGenerator.kt:555 */
   44     66   
    Ok(builder)
          67  +
    /* HttpBindingGenerator.kt:542 */
   45     68   
}
   46     69   
          70  +
/* JsonSerializerGenerator.kt:287 */
   47     71   
pub fn ser_malformed_boolean_input(
   48     72   
    input: &crate::operation::malformed_boolean::MalformedBooleanInput,
   49     73   
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
          74  +
    /* JsonSerializerGenerator.kt:291 */
   50     75   
    let mut out = String::new();
          76  +
    /* JsonSerializerGenerator.kt:292 */
   51     77   
    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
          78  +
    /* JsonSerializerGenerator.kt:375 */
   52     79   
    crate::protocol_serde::shape_malformed_boolean_input::ser_malformed_boolean_input_input(&mut object, input)?;
          80  +
    /* JsonSerializerGenerator.kt:295 */
   53     81   
    object.finish();
          82  +
    /* JsonSerializerGenerator.kt:296 */
   54     83   
    Ok(::aws_smithy_types::body::SdkBody::from(out))
          84  +
    /* JsonSerializerGenerator.kt:287 */
   55     85   
}