Client Test

Client Test

rev. 32b1b3c3761061baed26023be3219639e42d7d12

Files changed:

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

@@ -1,0 +13,0 @@
    1         -
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
    2         -
pub(crate) fn de_content_type_header(
    3         -
    header_map: &::aws_smithy_runtime_api::http::Headers,
    4         -
) -> ::std::result::Result<::std::option::Option<::std::string::String>, ::aws_smithy_http::header::ParseError> {
    5         -
    let headers = header_map.get_all("Content-Type");
    6         -
    ::aws_smithy_http::header::one_or_none(headers)
    7         -
}
    8         -
    9         -
pub(crate) fn de_data_payload(
   10         -
    body: &[u8],
   11         -
) -> std::result::Result<::std::option::Option<::aws_smithy_types::Blob>, crate::operation::test_payload_blob::TestPayloadBlobError> {
   12         -
    (!body.is_empty()).then(|| Ok(::aws_smithy_types::Blob::new(body))).transpose()
   13         -
}

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

@@ -1,0 +58,0 @@
    1         -
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
    2         -
#[allow(clippy::unnecessary_wraps)]
    3         -
pub fn de_test_payload_structure_http_error(
    4         -
    _response_status: u16,
    5         -
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
    6         -
    _response_body: &[u8],
    7         -
) -> std::result::Result<
    8         -
    crate::operation::test_payload_structure::TestPayloadStructureOutput,
    9         -
    crate::operation::test_payload_structure::TestPayloadStructureError,
   10         -
> {
   11         -
    #[allow(unused_mut)]
   12         -
    let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(_response_status, _response_headers, _response_body)
   13         -
        .map_err(crate::operation::test_payload_structure::TestPayloadStructureError::unhandled)?;
   14         -
    let generic = generic_builder.build();
   15         -
    Err(crate::operation::test_payload_structure::TestPayloadStructureError::generic(generic))
   16         -
}
   17         -
   18         -
#[allow(clippy::unnecessary_wraps)]
   19         -
pub fn de_test_payload_structure_http_response(
   20         -
    _response_status: u16,
   21         -
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
   22         -
    _response_body: &[u8],
   23         -
) -> std::result::Result<
   24         -
    crate::operation::test_payload_structure::TestPayloadStructureOutput,
   25         -
    crate::operation::test_payload_structure::TestPayloadStructureError,
   26         -
> {
   27         -
    Ok({
   28         -
        #[allow(unused_mut)]
   29         -
        let mut output = crate::operation::test_payload_structure::builders::TestPayloadStructureOutputBuilder::default();
   30         -
        output = output.set_payload_config(crate::protocol_serde::shape_test_payload_structure_output::de_payload_config_payload(
   31         -
            _response_body,
   32         -
        )?);
   33         -
        output = output.set_test_id(
   34         -
            crate::protocol_serde::shape_test_payload_structure_output::de_test_id_header(_response_headers).map_err(|_| {
   35         -
                crate::operation::test_payload_structure::TestPayloadStructureError::unhandled("Failed to parse testId from header `x-amz-test-id")
   36         -
            })?,
   37         -
        );
   38         -
        output.build()
   39         -
    })
   40         -
}
   41         -
   42         -
pub fn ser_test_payload_structure_headers(
   43         -
    input: &crate::operation::test_payload_structure::TestPayloadStructureInput,
   44         -
    mut builder: ::http_1x::request::Builder,
   45         -
) -> std::result::Result<::http_1x::request::Builder, ::aws_smithy_types::error::operation::BuildError> {
   46         -
    if let ::std::option::Option::Some(inner_1) = &input.test_id {
   47         -
        let formatted_2 = inner_1.as_str();
   48         -
        let header_value = formatted_2;
   49         -
        let header_value: ::http_1x::HeaderValue = header_value.parse().map_err(|err| {
   50         -
            ::aws_smithy_types::error::operation::BuildError::invalid_field(
   51         -
                "test_id",
   52         -
                format!("`{}` cannot be used as a header value: {}", &header_value, err),
   53         -
            )
   54         -
        })?;
   55         -
        builder = builder.header("x-amz-test-id", header_value);
   56         -
    }
   57         -
    Ok(builder)
   58         -
}

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

@@ -1,0 +22,0 @@
    1         -
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
    2         -
pub fn ser_payload_config_http_payload(
    3         -
    payload: &::std::option::Option<crate::types::PayloadConfig>,
    4         -
) -> ::std::result::Result<::std::vec::Vec<u8>, ::aws_smithy_types::error::operation::BuildError> {
    5         -
    let payload = match payload.as_ref() {
    6         -
        Some(t) => t,
    7         -
        None => return Ok(crate::protocol_serde::rest_json_unset_struct_payload()),
    8         -
    };
    9         -
    Ok(crate::protocol_serde::shape_test_payload_structure_input::ser_payload_config_payload(
   10         -
        payload,
   11         -
    )?)
   12         -
}
   13         -
   14         -
pub fn ser_payload_config_payload(
   15         -
    input: &crate::types::PayloadConfig,
   16         -
) -> std::result::Result<::std::vec::Vec<u8>, ::aws_smithy_types::error::operation::SerializationError> {
   17         -
    let mut out = String::new();
   18         -
    let mut object = ::aws_smithy_json::serialize::JsonObjectWriter::new(&mut out);
   19         -
    crate::protocol_serde::shape_payload_config::ser_payload_config(&mut object, input)?;
   20         -
    object.finish();
   21         -
    Ok(out.into_bytes())
   22         -
}

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

@@ -1,0 +18,0 @@
    1         -
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
    2         -
pub(crate) fn de_payload_config_payload(
    3         -
    body: &[u8],
    4         -
) -> std::result::Result<::std::option::Option<crate::types::PayloadConfig>, crate::operation::test_payload_structure::TestPayloadStructureError> {
    5         -
    (!body.is_empty())
    6         -
        .then(|| {
    7         -
            crate::protocol_serde::shape_payload_config::de_payload_config_payload(body)
    8         -
                .map_err(crate::operation::test_payload_structure::TestPayloadStructureError::unhandled)
    9         -
        })
   10         -
        .transpose()
   11         -
}
   12         -
   13         -
pub(crate) fn de_test_id_header(
   14         -
    header_map: &::aws_smithy_runtime_api::http::Headers,
   15         -
) -> ::std::result::Result<::std::option::Option<::std::string::String>, ::aws_smithy_http::header::ParseError> {
   16         -
    let headers = header_map.get_all("x-amz-test-id");
   17         -
    ::aws_smithy_http::header::one_or_none(headers)
   18         -
}

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

@@ -1,0 +41,0 @@
    1         -
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
    2         -
#[allow(clippy::unnecessary_wraps)]
    3         -
pub fn de_test_post_no_input_no_payload_http_error(
    4         -
    _response_status: u16,
    5         -
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
    6         -
    _response_body: &[u8],
    7         -
) -> std::result::Result<
    8         -
    crate::operation::test_post_no_input_no_payload::TestPostNoInputNoPayloadOutput,
    9         -
    crate::operation::test_post_no_input_no_payload::TestPostNoInputNoPayloadError,
   10         -
> {
   11         -
    #[allow(unused_mut)]
   12         -
    let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(_response_status, _response_headers, _response_body)
   13         -
        .map_err(crate::operation::test_post_no_input_no_payload::TestPostNoInputNoPayloadError::unhandled)?;
   14         -
    let generic = generic_builder.build();
   15         -
    Err(crate::operation::test_post_no_input_no_payload::TestPostNoInputNoPayloadError::generic(
   16         -
        generic,
   17         -
    ))
   18         -
}
   19         -
   20         -
#[allow(clippy::unnecessary_wraps)]
   21         -
pub fn de_test_post_no_input_no_payload_http_response(
   22         -
    _response_status: u16,
   23         -
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
   24         -
    _response_body: &[u8],
   25         -
) -> std::result::Result<
   26         -
    crate::operation::test_post_no_input_no_payload::TestPostNoInputNoPayloadOutput,
   27         -
    crate::operation::test_post_no_input_no_payload::TestPostNoInputNoPayloadError,
   28         -
> {
   29         -
    Ok({
   30         -
        #[allow(unused_mut)]
   31         -
        let mut output = crate::operation::test_post_no_input_no_payload::builders::TestPostNoInputNoPayloadOutputBuilder::default();
   32         -
        output = output.set_test_id(
   33         -
            crate::protocol_serde::shape_test_post_no_input_no_payload_output::de_test_id_header(_response_headers).map_err(|_| {
   34         -
                crate::operation::test_post_no_input_no_payload::TestPostNoInputNoPayloadError::unhandled(
   35         -
                    "Failed to parse testId from header `X-Amz-Test-Id",
   36         -
                )
   37         -
            })?,
   38         -
        );
   39         -
        output.build()
   40         -
    })
   41         -
}

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

@@ -1,0 +7,0 @@
    1         -
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
    2         -
pub(crate) fn de_test_id_header(
    3         -
    header_map: &::aws_smithy_runtime_api::http::Headers,
    4         -
) -> ::std::result::Result<::std::option::Option<::std::string::String>, ::aws_smithy_http::header::ParseError> {
    5         -
    let headers = header_map.get_all("X-Amz-Test-Id");
    6         -
    ::aws_smithy_http::header::one_or_none(headers)
    7         -
}

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

@@ -1,0 +55,0 @@
    1         -
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
    2         -
#[allow(clippy::unnecessary_wraps)]
    3         -
pub fn de_test_post_no_payload_http_error(
    4         -
    _response_status: u16,
    5         -
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
    6         -
    _response_body: &[u8],
    7         -
) -> std::result::Result<
    8         -
    crate::operation::test_post_no_payload::TestPostNoPayloadOutput,
    9         -
    crate::operation::test_post_no_payload::TestPostNoPayloadError,
   10         -
> {
   11         -
    #[allow(unused_mut)]
   12         -
    let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(_response_status, _response_headers, _response_body)
   13         -
        .map_err(crate::operation::test_post_no_payload::TestPostNoPayloadError::unhandled)?;
   14         -
    let generic = generic_builder.build();
   15         -
    Err(crate::operation::test_post_no_payload::TestPostNoPayloadError::generic(generic))
   16         -
}
   17         -
   18         -
#[allow(clippy::unnecessary_wraps)]
   19         -
pub fn de_test_post_no_payload_http_response(
   20         -
    _response_status: u16,
   21         -
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
   22         -
    _response_body: &[u8],
   23         -
) -> std::result::Result<
   24         -
    crate::operation::test_post_no_payload::TestPostNoPayloadOutput,
   25         -
    crate::operation::test_post_no_payload::TestPostNoPayloadError,
   26         -
> {
   27         -
    Ok({
   28         -
        #[allow(unused_mut)]
   29         -
        let mut output = crate::operation::test_post_no_payload::builders::TestPostNoPayloadOutputBuilder::default();
   30         -
        output = output.set_test_id(
   31         -
            crate::protocol_serde::shape_test_post_no_payload_output::de_test_id_header(_response_headers).map_err(|_| {
   32         -
                crate::operation::test_post_no_payload::TestPostNoPayloadError::unhandled("Failed to parse testId from header `X-Amz-Test-Id")
   33         -
            })?,
   34         -
        );
   35         -
        output.build()
   36         -
    })
   37         -
}
   38         -
   39         -
pub fn ser_test_post_no_payload_headers(
   40         -
    input: &crate::operation::test_post_no_payload::TestPostNoPayloadInput,
   41         -
    mut builder: ::http_1x::request::Builder,
   42         -
) -> std::result::Result<::http_1x::request::Builder, ::aws_smithy_types::error::operation::BuildError> {
   43         -
    if let ::std::option::Option::Some(inner_1) = &input.test_id {
   44         -
        let formatted_2 = inner_1.as_str();
   45         -
        let header_value = formatted_2;
   46         -
        let header_value: ::http_1x::HeaderValue = header_value.parse().map_err(|err| {
   47         -
            ::aws_smithy_types::error::operation::BuildError::invalid_field(
   48         -
                "test_id",
   49         -
                format!("`{}` cannot be used as a header value: {}", &header_value, err),
   50         -
            )
   51         -
        })?;
   52         -
        builder = builder.header("X-Amz-Test-Id", header_value);
   53         -
    }
   54         -
    Ok(builder)
   55         -
}

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

@@ -1,0 +7,0 @@
    1         -
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
    2         -
pub(crate) fn de_test_id_header(
    3         -
    header_map: &::aws_smithy_runtime_api::http::Headers,
    4         -
) -> ::std::result::Result<::std::option::Option<::std::string::String>, ::aws_smithy_http::header::ParseError> {
    5         -
    let headers = header_map.get_all("X-Amz-Test-Id");
    6         -
    ::aws_smithy_http::header::one_or_none(headers)
    7         -
}

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

@@ -1,0 +39,0 @@
    1         -
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
    2         -
pub(crate) fn de_test_string_list<'a, I>(
    3         -
    tokens: &mut ::std::iter::Peekable<I>,
    4         -
    _value: &'a [u8],
    5         -
) -> ::std::result::Result<Option<::std::vec::Vec<::std::string::String>>, ::aws_smithy_json::deserialize::error::DeserializeError>
    6         -
where
    7         -
    I: Iterator<Item = Result<::aws_smithy_json::deserialize::Token<'a>, ::aws_smithy_json::deserialize::error::DeserializeError>>,
    8         -
{
    9         -
    match tokens.next().transpose()? {
   10         -
        Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
   11         -
        Some(::aws_smithy_json::deserialize::Token::StartArray { .. }) => {
   12         -
            let mut items = Vec::new();
   13         -
            loop {
   14         -
                match tokens.peek() {
   15         -
                    Some(Ok(::aws_smithy_json::deserialize::Token::EndArray { .. })) => {
   16         -
                        tokens.next().transpose().unwrap();
   17         -
                        break;
   18         -
                    }
   19         -
                    _ => {
   20         -
                        let value = ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   21         -
                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   22         -
                            .transpose()?;
   23         -
                        if let Some(value) = value {
   24         -
                            items.push(value);
   25         -
                        } else {
   26         -
                            return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   27         -
                                "dense list cannot contain null values",
   28         -
                            ));
   29         -
                        }
   30         -
                    }
   31         -
                }
   32         -
            }
   33         -
            Ok(Some(items))
   34         -
        }
   35         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   36         -
            "expected start array or null",
   37         -
        )),
   38         -
    }
   39         -
}

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

@@ -1,0 +48,0 @@
    1         -
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
    2         -
pub(crate) fn de_test_string_map<'a, I>(
    3         -
    tokens: &mut ::std::iter::Peekable<I>,
    4         -
    _value: &'a [u8],
    5         -
) -> ::std::result::Result<
    6         -
    Option<::std::collections::HashMap<::std::string::String, ::std::string::String>>,
    7         -
    ::aws_smithy_json::deserialize::error::DeserializeError,
    8         -
>
    9         -
where
   10         -
    I: Iterator<Item = Result<::aws_smithy_json::deserialize::Token<'a>, ::aws_smithy_json::deserialize::error::DeserializeError>>,
   11         -
{
   12         -
    match tokens.next().transpose()? {
   13         -
        Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
   14         -
        Some(::aws_smithy_json::deserialize::Token::StartObject { .. }) => {
   15         -
            let mut map = ::std::collections::HashMap::new();
   16         -
            loop {
   17         -
                match tokens.next().transpose()? {
   18         -
                    Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   19         -
                    Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
   20         -
                        let key = key.to_unescaped().map(|u| u.into_owned())?;
   21         -
                        let value = ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   22         -
                            .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   23         -
                            .transpose()?;
   24         -
                        match value {
   25         -
                            Some(value) => {
   26         -
                                map.insert(key, value);
   27         -
                            }
   28         -
                            None => {
   29         -
                                return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   30         -
                                    "dense map cannot contain null values",
   31         -
                                ))
   32         -
                            }
   33         -
                        }
   34         -
                    }
   35         -
                    other => {
   36         -
                        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   37         -
                            "expected object key or end object, found: {other:?}"
   38         -
                        )))
   39         -
                    }
   40         -
                }
   41         -
            }
   42         -
            Ok(Some(map))
   43         -
        }
   44         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   45         -
            "expected start object or null",
   46         -
        )),
   47         -
    }
   48         -
}

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

@@ -1,0 +165,0 @@
    1         -
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
    2         -
#[allow(clippy::unnecessary_wraps)]
    3         -
pub fn de_timestamp_format_headers_http_error(
    4         -
    _response_status: u16,
    5         -
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
    6         -
    _response_body: &[u8],
    7         -
) -> std::result::Result<
    8         -
    crate::operation::timestamp_format_headers::TimestampFormatHeadersOutput,
    9         -
    crate::operation::timestamp_format_headers::TimestampFormatHeadersError,
   10         -
> {
   11         -
    #[allow(unused_mut)]
   12         -
    let mut generic_builder = crate::protocol_serde::parse_http_error_metadata(_response_status, _response_headers, _response_body)
   13         -
        .map_err(crate::operation::timestamp_format_headers::TimestampFormatHeadersError::unhandled)?;
   14         -
    let generic = generic_builder.build();
   15         -
    Err(crate::operation::timestamp_format_headers::TimestampFormatHeadersError::generic(generic))
   16         -
}
   17         -
   18         -
#[allow(clippy::unnecessary_wraps)]
   19         -
pub fn de_timestamp_format_headers_http_response(
   20         -
    _response_status: u16,
   21         -
    _response_headers: &::aws_smithy_runtime_api::http::Headers,
   22         -
    _response_body: &[u8],
   23         -
) -> std::result::Result<
   24         -
    crate::operation::timestamp_format_headers::TimestampFormatHeadersOutput,
   25         -
    crate::operation::timestamp_format_headers::TimestampFormatHeadersError,
   26         -
> {
   27         -
    Ok({
   28         -
        #[allow(unused_mut)]
   29         -
        let mut output = crate::operation::timestamp_format_headers::builders::TimestampFormatHeadersOutputBuilder::default();
   30         -
        output = output.set_default_format(
   31         -
            crate::protocol_serde::shape_timestamp_format_headers_output::de_default_format_header(_response_headers).map_err(|_| {
   32         -
                crate::operation::timestamp_format_headers::TimestampFormatHeadersError::unhandled(
   33         -
                    "Failed to parse defaultFormat from header `X-defaultFormat",
   34         -
                )
   35         -
            })?,
   36         -
        );
   37         -
        output = output.set_member_date_time(
   38         -
            crate::protocol_serde::shape_timestamp_format_headers_output::de_member_date_time_header(_response_headers).map_err(|_| {
   39         -
                crate::operation::timestamp_format_headers::TimestampFormatHeadersError::unhandled(
   40         -
                    "Failed to parse memberDateTime from header `X-memberDateTime",
   41         -
                )
   42         -
            })?,
   43         -
        );
   44         -
        output = output.set_member_epoch_seconds(
   45         -
            crate::protocol_serde::shape_timestamp_format_headers_output::de_member_epoch_seconds_header(_response_headers).map_err(|_| {
   46         -
                crate::operation::timestamp_format_headers::TimestampFormatHeadersError::unhandled(
   47         -
                    "Failed to parse memberEpochSeconds from header `X-memberEpochSeconds",
   48         -
                )
   49         -
            })?,
   50         -
        );
   51         -
        output = output.set_member_http_date(
   52         -
            crate::protocol_serde::shape_timestamp_format_headers_output::de_member_http_date_header(_response_headers).map_err(|_| {
   53         -
                crate::operation::timestamp_format_headers::TimestampFormatHeadersError::unhandled(
   54         -
                    "Failed to parse memberHttpDate from header `X-memberHttpDate",
   55         -
                )
   56         -
            })?,
   57         -
        );
   58         -
        output = output.set_target_date_time(
   59         -
            crate::protocol_serde::shape_timestamp_format_headers_output::de_target_date_time_header(_response_headers).map_err(|_| {
   60         -
                crate::operation::timestamp_format_headers::TimestampFormatHeadersError::unhandled(
   61         -
                    "Failed to parse targetDateTime from header `X-targetDateTime",
   62         -
                )
   63         -
            })?,
   64         -
        );
   65         -
        output = output.set_target_epoch_seconds(
   66         -
            crate::protocol_serde::shape_timestamp_format_headers_output::de_target_epoch_seconds_header(_response_headers).map_err(|_| {
   67         -
                crate::operation::timestamp_format_headers::TimestampFormatHeadersError::unhandled(
   68         -
                    "Failed to parse targetEpochSeconds from header `X-targetEpochSeconds",
   69         -
                )
   70         -
            })?,
   71         -
        );
   72         -
        output = output.set_target_http_date(
   73         -
            crate::protocol_serde::shape_timestamp_format_headers_output::de_target_http_date_header(_response_headers).map_err(|_| {
   74         -
                crate::operation::timestamp_format_headers::TimestampFormatHeadersError::unhandled(
   75         -
                    "Failed to parse targetHttpDate from header `X-targetHttpDate",
   76         -
                )
   77         -
            })?,
   78         -
        );
   79         -
        output.build()
   80         -
    })
   81         -
}
   82         -
   83         -
pub fn ser_timestamp_format_headers_headers(
   84         -
    input: &crate::operation::timestamp_format_headers::TimestampFormatHeadersInput,
   85         -
    mut builder: ::http_1x::request::Builder,
   86         -
) -> std::result::Result<::http_1x::request::Builder, ::aws_smithy_types::error::operation::BuildError> {
   87         -
    if let ::std::option::Option::Some(inner_1) = &input.member_epoch_seconds {
   88         -
        let formatted_2 = inner_1.fmt(::aws_smithy_types::date_time::Format::EpochSeconds)?;
   89         -
        let header_value = formatted_2;
   90         -
        let header_value: ::http_1x::HeaderValue = header_value.parse().map_err(|err| {
   91         -
            ::aws_smithy_types::error::operation::BuildError::invalid_field(
   92         -
                "member_epoch_seconds",
   93         -
                format!("`{}` cannot be used as a header value: {}", &header_value, err),
   94         -
            )
   95         -
        })?;
   96         -
        builder = builder.header("X-memberEpochSeconds", header_value);
   97         -
    }
   98         -
    if let ::std::option::Option::Some(inner_3) = &input.member_http_date {
   99         -
        let formatted_4 = inner_3.fmt(::aws_smithy_types::date_time::Format::HttpDate)?;
  100         -
        let header_value = formatted_4;
  101         -
        let header_value: ::http_1x::HeaderValue = header_value.parse().map_err(|err| {
  102         -
            ::aws_smithy_types::error::operation::BuildError::invalid_field(
  103         -
                "member_http_date",
  104         -
                format!("`{}` cannot be used as a header value: {}", &header_value, err),
  105         -
            )
  106         -
        })?;
  107         -
        builder = builder.header("X-memberHttpDate", header_value);
  108         -
    }
  109         -
    if let ::std::option::Option::Some(inner_5) = &input.member_date_time {
  110         -
        let formatted_6 = inner_5.fmt(::aws_smithy_types::date_time::Format::DateTime)?;
  111         -
        let header_value = formatted_6;
  112         -
        let header_value: ::http_1x::HeaderValue = header_value.parse().map_err(|err| {
  113         -
            ::aws_smithy_types::error::operation::BuildError::invalid_field(
  114         -
                "member_date_time",
  115         -
                format!("`{}` cannot be used as a header value: {}", &header_value, err),
  116         -
            )
  117         -
        })?;
  118         -
        builder = builder.header("X-memberDateTime", header_value);
  119         -
    }
  120         -
    if let ::std::option::Option::Some(inner_7) = &input.default_format {
  121         -
        let formatted_8 = inner_7.fmt(::aws_smithy_types::date_time::Format::HttpDate)?;
  122         -
        let header_value = formatted_8;
  123         -
        let header_value: ::http_1x::HeaderValue = header_value.parse().map_err(|err| {
  124         -
            ::aws_smithy_types::error::operation::BuildError::invalid_field(
  125         -
                "default_format",
  126         -
                format!("`{}` cannot be used as a header value: {}", &header_value, err),
  127         -
            )
  128         -
        })?;
  129         -
        builder = builder.header("X-defaultFormat", header_value);
  130         -
    }
  131         -
    if let ::std::option::Option::Some(inner_9) = &input.target_epoch_seconds {
  132         -
        let formatted_10 = inner_9.fmt(::aws_smithy_types::date_time::Format::EpochSeconds)?;
  133         -
        let header_value = formatted_10;
  134         -
        let header_value: ::http_1x::HeaderValue = header_value.parse().map_err(|err| {
  135         -
            ::aws_smithy_types::error::operation::BuildError::invalid_field(
  136         -
                "target_epoch_seconds",
  137         -
                format!("`{}` cannot be used as a header value: {}", &header_value, err),
  138         -
            )
  139         -
        })?;
  140         -
        builder = builder.header("X-targetEpochSeconds", header_value);
  141         -
    }
  142         -
    if let ::std::option::Option::Some(inner_11) = &input.target_http_date {
  143         -
        let formatted_12 = inner_11.fmt(::aws_smithy_types::date_time::Format::HttpDate)?;
  144         -
        let header_value = formatted_12;
  145         -
        let header_value: ::http_1x::HeaderValue = header_value.parse().map_err(|err| {
  146         -
            ::aws_smithy_types::error::operation::BuildError::invalid_field(
  147         -
                "target_http_date",
  148         -
                format!("`{}` cannot be used as a header value: {}", &header_value, err),
  149         -
            )
  150         -
        })?;
  151         -
        builder = builder.header("X-targetHttpDate", header_value);
  152         -
    }
  153         -
    if let ::std::option::Option::Some(inner_13) = &input.target_date_time {
  154         -
        let formatted_14 = inner_13.fmt(::aws_smithy_types::date_time::Format::DateTime)?;
  155         -
        let header_value = formatted_14;
  156         -
        let header_value: ::http_1x::HeaderValue = header_value.parse().map_err(|err| {
  157         -
            ::aws_smithy_types::error::operation::BuildError::invalid_field(
  158         -
                "target_date_time",
  159         -
                format!("`{}` cannot be used as a header value: {}", &header_value, err),
  160         -
            )
  161         -
        })?;
  162         -
        builder = builder.header("X-targetDateTime", header_value);
  163         -
    }
  164         -
    Ok(builder)
  165         -
}

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

@@ -1,0 +116,0 @@
    1         -
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
    2         -
pub(crate) fn de_default_format_header(
    3         -
    header_map: &::aws_smithy_runtime_api::http::Headers,
    4         -
) -> ::std::result::Result<::std::option::Option<::aws_smithy_types::DateTime>, ::aws_smithy_http::header::ParseError> {
    5         -
    let headers = header_map.get_all("X-defaultFormat");
    6         -
    let var_1: Vec<::aws_smithy_types::DateTime> = ::aws_smithy_http::header::many_dates(headers, ::aws_smithy_types::date_time::Format::HttpDate)?;
    7         -
    if var_1.len() > 1 {
    8         -
        Err(::aws_smithy_http::header::ParseError::new(format!(
    9         -
            "expected one item but found {}",
   10         -
            var_1.len()
   11         -
        )))
   12         -
    } else {
   13         -
        let mut var_1 = var_1;
   14         -
        Ok(var_1.pop())
   15         -
    }
   16         -
}
   17         -
   18         -
pub(crate) fn de_member_date_time_header(
   19         -
    header_map: &::aws_smithy_runtime_api::http::Headers,
   20         -
) -> ::std::result::Result<::std::option::Option<::aws_smithy_types::DateTime>, ::aws_smithy_http::header::ParseError> {
   21         -
    let headers = header_map.get_all("X-memberDateTime");
   22         -
    let var_2: Vec<::aws_smithy_types::DateTime> =
   23         -
        ::aws_smithy_http::header::many_dates(headers, ::aws_smithy_types::date_time::Format::DateTimeWithOffset)?;
   24         -
    if var_2.len() > 1 {
   25         -
        Err(::aws_smithy_http::header::ParseError::new(format!(
   26         -
            "expected one item but found {}",
   27         -
            var_2.len()
   28         -
        )))
   29         -
    } else {
   30         -
        let mut var_2 = var_2;
   31         -
        Ok(var_2.pop())
   32         -
    }
   33         -
}
   34         -
   35         -
pub(crate) fn de_member_epoch_seconds_header(
   36         -
    header_map: &::aws_smithy_runtime_api::http::Headers,
   37         -
) -> ::std::result::Result<::std::option::Option<::aws_smithy_types::DateTime>, ::aws_smithy_http::header::ParseError> {
   38         -
    let headers = header_map.get_all("X-memberEpochSeconds");
   39         -
    let var_3: Vec<::aws_smithy_types::DateTime> =
   40         -
        ::aws_smithy_http::header::many_dates(headers, ::aws_smithy_types::date_time::Format::EpochSeconds)?;
   41         -
    if var_3.len() > 1 {
   42         -
        Err(::aws_smithy_http::header::ParseError::new(format!(
   43         -
            "expected one item but found {}",
   44         -
            var_3.len()
   45         -
        )))
   46         -
    } else {
   47         -
        let mut var_3 = var_3;
   48         -
        Ok(var_3.pop())
   49         -
    }
   50         -
}
   51         -
   52         -
pub(crate) fn de_member_http_date_header(
   53         -
    header_map: &::aws_smithy_runtime_api::http::Headers,
   54         -
) -> ::std::result::Result<::std::option::Option<::aws_smithy_types::DateTime>, ::aws_smithy_http::header::ParseError> {
   55         -
    let headers = header_map.get_all("X-memberHttpDate");
   56         -
    let var_4: Vec<::aws_smithy_types::DateTime> = ::aws_smithy_http::header::many_dates(headers, ::aws_smithy_types::date_time::Format::HttpDate)?;
   57         -
    if var_4.len() > 1 {
   58         -
        Err(::aws_smithy_http::header::ParseError::new(format!(
   59         -
            "expected one item but found {}",
   60         -
            var_4.len()
   61         -
        )))
   62         -
    } else {
   63         -
        let mut var_4 = var_4;
   64         -
        Ok(var_4.pop())
   65         -
    }
   66         -
}
   67         -
   68         -
pub(crate) fn de_target_date_time_header(
   69         -
    header_map: &::aws_smithy_runtime_api::http::Headers,
   70         -
) -> ::std::result::Result<::std::option::Option<::aws_smithy_types::DateTime>, ::aws_smithy_http::header::ParseError> {
   71         -
    let headers = header_map.get_all("X-targetDateTime");
   72         -
    let var_5: Vec<::aws_smithy_types::DateTime> =
   73         -
        ::aws_smithy_http::header::many_dates(headers, ::aws_smithy_types::date_time::Format::DateTimeWithOffset)?;
   74         -
    if var_5.len() > 1 {
   75         -
        Err(::aws_smithy_http::header::ParseError::new(format!(
   76         -
            "expected one item but found {}",
   77         -
            var_5.len()
   78         -
        )))
   79         -
    } else {
   80         -
        let mut var_5 = var_5;
   81         -
        Ok(var_5.pop())
   82         -
    }
   83         -
}
   84         -
   85         -
pub(crate) fn de_target_epoch_seconds_header(
   86         -
    header_map: &::aws_smithy_runtime_api::http::Headers,
   87         -
) -> ::std::result::Result<::std::option::Option<::aws_smithy_types::DateTime>, ::aws_smithy_http::header::ParseError> {
   88         -
    let headers = header_map.get_all("X-targetEpochSeconds");
   89         -
    let var_6: Vec<::aws_smithy_types::DateTime> =
   90         -
        ::aws_smithy_http::header::many_dates(headers, ::aws_smithy_types::date_time::Format::EpochSeconds)?;
   91         -
    if var_6.len() > 1 {
   92         -
        Err(::aws_smithy_http::header::ParseError::new(format!(
   93         -
            "expected one item but found {}",
   94         -
            var_6.len()
   95         -
        )))
   96         -
    } else {
   97         -
        let mut var_6 = var_6;
   98         -
        Ok(var_6.pop())
   99         -
    }
  100         -
}
  101         -
  102         -
pub(crate) fn de_target_http_date_header(
  103         -
    header_map: &::aws_smithy_runtime_api::http::Headers,
  104         -
) -> ::std::result::Result<::std::option::Option<::aws_smithy_types::DateTime>, ::aws_smithy_http::header::ParseError> {
  105         -
    let headers = header_map.get_all("X-targetHttpDate");
  106         -
    let var_7: Vec<::aws_smithy_types::DateTime> = ::aws_smithy_http::header::many_dates(headers, ::aws_smithy_types::date_time::Format::HttpDate)?;
  107         -
    if var_7.len() > 1 {
  108         -
        Err(::aws_smithy_http::header::ParseError::new(format!(
  109         -
            "expected one item but found {}",
  110         -
            var_7.len()
  111         -
        )))
  112         -
    } else {
  113         -
        let mut var_7 = var_7;
  114         -
        Ok(var_7.pop())
  115         -
    }
  116         -
}

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

@@ -1,0 +40,0 @@
    1         -
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
    2         -
pub(crate) fn de_timestamp_list<'a, I>(
    3         -
    tokens: &mut ::std::iter::Peekable<I>,
    4         -
    _value: &'a [u8],
    5         -
) -> ::std::result::Result<Option<::std::vec::Vec<::aws_smithy_types::DateTime>>, ::aws_smithy_json::deserialize::error::DeserializeError>
    6         -
where
    7         -
    I: Iterator<Item = Result<::aws_smithy_json::deserialize::Token<'a>, ::aws_smithy_json::deserialize::error::DeserializeError>>,
    8         -
{
    9         -
    match tokens.next().transpose()? {
   10         -
        Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
   11         -
        Some(::aws_smithy_json::deserialize::Token::StartArray { .. }) => {
   12         -
            let mut items = Vec::new();
   13         -
            loop {
   14         -
                match tokens.peek() {
   15         -
                    Some(Ok(::aws_smithy_json::deserialize::Token::EndArray { .. })) => {
   16         -
                        tokens.next().transpose().unwrap();
   17         -
                        break;
   18         -
                    }
   19         -
                    _ => {
   20         -
                        let value = ::aws_smithy_json::deserialize::token::expect_timestamp_or_null(
   21         -
                            tokens.next(),
   22         -
                            ::aws_smithy_types::date_time::Format::EpochSeconds,
   23         -
                        )?;
   24         -
                        if let Some(value) = value {
   25         -
                            items.push(value);
   26         -
                        } else {
   27         -
                            return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   28         -
                                "dense list cannot contain null values",
   29         -
                            ));
   30         -
                        }
   31         -
                    }
   32         -
                }
   33         -
            }
   34         -
            Ok(Some(items))
   35         -
        }
   36         -
        _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   37         -
            "expected start array or null",
   38         -
        )),
   39         -
    }
   40         -
}

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

@@ -1,0 +38,0 @@
    1         -
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
    2         -
pub fn ser_top_level(
    3         -
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4         -
    input: &crate::types::TopLevel,
    5         -
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
    6         -
    {
    7         -
        #[allow(unused_mut)]
    8         -
        let mut object_1 = object.key("dialog").start_object();
    9         -
        crate::protocol_serde::shape_dialog::ser_dialog(&mut object_1, &input.dialog)?;
   10         -
        object_1.finish();
   11         -
    }
   12         -
    {
   13         -
        let mut array_2 = object.key("dialogList").start_array();
   14         -
        for item_3 in &input.dialog_list {
   15         -
            {
   16         -
                #[allow(unused_mut)]
   17         -
                let mut object_4 = array_2.value().start_object();
   18         -
                crate::protocol_serde::shape_dialog::ser_dialog(&mut object_4, item_3)?;
   19         -
                object_4.finish();
   20         -
            }
   21         -
        }
   22         -
        array_2.finish();
   23         -
    }
   24         -
    {
   25         -
        #[allow(unused_mut)]
   26         -
        let mut object_5 = object.key("dialogMap").start_object();
   27         -
        for (key_6, value_7) in &input.dialog_map {
   28         -
            {
   29         -
                #[allow(unused_mut)]
   30         -
                let mut object_8 = object_5.key(key_6.as_str()).start_object();
   31         -
                crate::protocol_serde::shape_dialog::ser_dialog(&mut object_8, value_7)?;
   32         -
                object_8.finish();
   33         -
            }
   34         -
        }
   35         -
        object_5.finish();
   36         -
    }
   37         -
    Ok(())
   38         -
}

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

@@ -1,0 +94,0 @@
    1         -
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
    2         -
pub fn ser_union_payload(
    3         -
    object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
    4         -
    input: &crate::types::UnionPayload,
    5         -
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
    6         -
    match input {
    7         -
        crate::types::UnionPayload::Greeting(inner) => {
    8         -
            object.key("greeting").string(inner.as_str());
    9         -
        }
   10         -
        crate::types::UnionPayload::Unknown => return Err(::aws_smithy_types::error::operation::SerializationError::unknown_variant("UnionPayload")),
   11         -
    }
   12         -
    Ok(())
   13         -
}
   14         -
   15         -
pub(crate) fn de_union_payload_payload(
   16         -
    _value: &[u8],
   17         -
) -> ::std::result::Result<crate::types::UnionPayload, ::aws_smithy_json::deserialize::error::DeserializeError> {
   18         -
    let mut tokens_owned = ::aws_smithy_json::deserialize::json_token_iter(crate::protocol_serde::or_empty_doc(_value)).peekable();
   19         -
    let tokens = &mut tokens_owned;
   20         -
    let result = crate::protocol_serde::shape_union_payload::de_union_payload(tokens, _value)?
   21         -
        .ok_or_else(|| ::aws_smithy_json::deserialize::error::DeserializeError::custom("expected payload member value"));
   22         -
    if tokens.next().is_some() {
   23         -
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   24         -
            "found more JSON tokens after completing parsing",
   25         -
        ));
   26         -
    }
   27         -
    result
   28         -
}
   29         -
   30         -
pub(crate) fn de_union_payload<'a, I>(
   31         -
    tokens: &mut ::std::iter::Peekable<I>,
   32         -
    _value: &'a [u8],
   33         -
) -> ::std::result::Result<Option<crate::types::UnionPayload>, ::aws_smithy_json::deserialize::error::DeserializeError>
   34         -
where
   35         -
    I: Iterator<Item = Result<::aws_smithy_json::deserialize::Token<'a>, ::aws_smithy_json::deserialize::error::DeserializeError>>,
   36         -
{
   37         -
    let mut variant = None;
   38         -
    match tokens.next().transpose()? {
   39         -
        Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => return Ok(None),
   40         -
        Some(::aws_smithy_json::deserialize::Token::StartObject { .. }) => loop {
   41         -
            match tokens.next().transpose()? {
   42         -
                Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   43         -
                Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
   44         -
                    if let ::std::option::Option::Some(::std::result::Result::Ok(::aws_smithy_json::deserialize::Token::ValueNull { .. })) =
   45         -
                        tokens.peek()
   46         -
                    {
   47         -
                        let _ = tokens.next().expect("peek returned a token")?;
   48         -
                        continue;
   49         -
                    }
   50         -
                    let key = key.to_unescaped()?;
   51         -
                    if key == "__type" {
   52         -
                        ::aws_smithy_json::deserialize::token::skip_value(tokens)?;
   53         -
                        continue;
   54         -
                    }
   55         -
                    if variant.is_some() {
   56         -
                        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   57         -
                            "encountered mixed variants in union",
   58         -
                        ));
   59         -
                    }
   60         -
                    variant = match key.as_ref() {
   61         -
                        "greeting" => Some(crate::types::UnionPayload::Greeting(
   62         -
                            ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   63         -
                                .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   64         -
                                .transpose()?
   65         -
                                .ok_or_else(|| {
   66         -
                                    ::aws_smithy_json::deserialize::error::DeserializeError::custom("value for 'greeting' cannot be null")
   67         -
                                })?,
   68         -
                        )),
   69         -
                        _ => {
   70         -
                            ::aws_smithy_json::deserialize::token::skip_value(tokens)?;
   71         -
                            Some(crate::types::UnionPayload::Unknown)
   72         -
                        }
   73         -
                    };
   74         -
                }
   75         -
                other => {
   76         -
                    return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   77         -
                        "expected object key or end object, found: {other:?}"
   78         -
                    )))
   79         -
                }
   80         -
            }
   81         -
        },
   82         -
        _ => {
   83         -
            return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   84         -
                "expected start object or null",
   85         -
            ))
   86         -
        }
   87         -
    }
   88         -
    if variant.is_none() {
   89         -
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   90         -
            "Union did not contain a valid variant.",
   91         -
        ));
   92         -
    }
   93         -
    Ok(variant)
   94         -
}

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

@@ -1,0 +99,0 @@
    1         -
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
    2         -
pub(crate) fn de_union_with_json_name<'a, I>(
    3         -
    tokens: &mut ::std::iter::Peekable<I>,
    4         -
    _value: &'a [u8],
    5         -
) -> ::std::result::Result<Option<crate::types::UnionWithJsonName>, ::aws_smithy_json::deserialize::error::DeserializeError>
    6         -
where
    7         -
    I: Iterator<Item = Result<::aws_smithy_json::deserialize::Token<'a>, ::aws_smithy_json::deserialize::error::DeserializeError>>,
    8         -
{
    9         -
    let mut variant = None;
   10         -
    match tokens.next().transpose()? {
   11         -
        Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => return Ok(None),
   12         -
        Some(::aws_smithy_json::deserialize::Token::StartObject { .. }) => loop {
   13         -
            match tokens.next().transpose()? {
   14         -
                Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
   15         -
                Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => {
   16         -
                    if let ::std::option::Option::Some(::std::result::Result::Ok(::aws_smithy_json::deserialize::Token::ValueNull { .. })) =
   17         -
                        tokens.peek()
   18         -
                    {
   19         -
                        let _ = tokens.next().expect("peek returned a token")?;
   20         -
                        continue;
   21         -
                    }
   22         -
                    let key = key.to_unescaped()?;
   23         -
                    if key == "__type" {
   24         -
                        ::aws_smithy_json::deserialize::token::skip_value(tokens)?;
   25         -
                        continue;
   26         -
                    }
   27         -
                    if variant.is_some() {
   28         -
                        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   29         -
                            "encountered mixed variants in union",
   30         -
                        ));
   31         -
                    }
   32         -
                    variant = match key.as_ref() {
   33         -
                        "FOO" => Some(crate::types::UnionWithJsonName::Foo(
   34         -
                            ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   35         -
                                .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   36         -
                                .transpose()?
   37         -
                                .ok_or_else(|| ::aws_smithy_json::deserialize::error::DeserializeError::custom("value for 'foo' cannot be null"))?,
   38         -
                        )),
   39         -
                        "bar" => Some(crate::types::UnionWithJsonName::Bar(
   40         -
                            ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   41         -
                                .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   42         -
                                .transpose()?
   43         -
                                .ok_or_else(|| ::aws_smithy_json::deserialize::error::DeserializeError::custom("value for 'bar' cannot be null"))?,
   44         -
                        )),
   45         -
                        "_baz" => Some(crate::types::UnionWithJsonName::Baz(
   46         -
                            ::aws_smithy_json::deserialize::token::expect_string_or_null(tokens.next())?
   47         -
                                .map(|s| s.to_unescaped().map(|u| u.into_owned()))
   48         -
                                .transpose()?
   49         -
                                .ok_or_else(|| ::aws_smithy_json::deserialize::error::DeserializeError::custom("value for 'baz' cannot be null"))?,
   50         -
                        )),
   51         -
                        _ => {
   52         -
                            ::aws_smithy_json::deserialize::token::skip_value(tokens)?;
   53         -
                            Some(crate::types::UnionWithJsonName::Unknown)
   54         -
                        }
   55         -
                    };
   56         -
                }
   57         -
                other => {
   58         -
                    return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
   59         -
                        "expected object key or end object, found: {other:?}"
   60         -
                    )))
   61         -
                }
   62         -
            }
   63         -
        },
   64         -
        _ => {
   65         -
            return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   66         -
                "expected start object or null",
   67         -
            ))
   68         -
        }
   69         -
    }
   70         -
    if variant.is_none() {
   71         -
        return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
   72         -
            "Union did not contain a valid variant.",
   73         -
        ));
   74         -
    }
   75         -
    Ok(variant)
   76         -
}
   77         -
   78         -
pub fn ser_union_with_json_name(
   79         -
    object_2: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
   80         -
    input: &crate::types::UnionWithJsonName,
   81         -
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
   82         -
    match input {
   83         -
        crate::types::UnionWithJsonName::Foo(inner) => {
   84         -
            object_2.key("FOO").string(inner.as_str());
   85         -
        }
   86         -
        crate::types::UnionWithJsonName::Bar(inner) => {
   87         -
            object_2.key("bar").string(inner.as_str());
   88         -
        }
   89         -
        crate::types::UnionWithJsonName::Baz(inner) => {
   90         -
            object_2.key("_baz").string(inner.as_str());
   91         -
        }
   92         -
        crate::types::UnionWithJsonName::Unknown => {
   93         -
            return Err(::aws_smithy_types::error::operation::SerializationError::unknown_variant(
   94         -
                "UnionWithJsonName",
   95         -
            ))
   96         -
        }
   97         -
    }
   98         -
    Ok(())
   99         -
}