AWS SDK

AWS SDK

rev. ec7b2441254af868911fccffe8d8dca83aff0045 (ignoring whitespace)

Files changed:

tmp-codegen-diff/aws-sdk/sdk/ec2/src/operation/copy_image.rs

@@ -1,1 +40,44 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
    2      2   
/// Orchestration and serialization glue logic for `CopyImage`.
    3      3   
#[derive(::std::clone::Clone, ::std::default::Default, ::std::fmt::Debug)]
    4      4   
#[non_exhaustive]
    5      5   
pub struct CopyImage;
    6      6   
impl CopyImage {
    7      7   
    /// Creates a new `CopyImage`
    8      8   
    pub fn new() -> Self {
    9      9   
        Self
   10     10   
    }
          11  +
    /// The schema for this operation's input shape.
          12  +
    pub const INPUT_SCHEMA: &'static ::aws_smithy_schema::Schema = crate::operation::copy_image::CopyImageInput::SCHEMA;
          13  +
    /// The schema for this operation's output shape.
          14  +
    pub const OUTPUT_SCHEMA: &'static ::aws_smithy_schema::Schema = crate::operation::copy_image::CopyImageOutput::SCHEMA;
   11     15   
    pub(crate) async fn orchestrate(
   12     16   
        runtime_plugins: &::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins,
   13     17   
        input: crate::operation::copy_image::CopyImageInput,
   14     18   
    ) -> ::std::result::Result<
   15     19   
        crate::operation::copy_image::CopyImageOutput,
   16     20   
        ::aws_smithy_runtime_api::client::result::SdkError<
   17     21   
            crate::operation::copy_image::CopyImageError,
   18     22   
            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
   19     23   
        >,
   20     24   
    > {
@@ -122,126 +184,189 @@
  142    146   
                crate::operation::copy_image::CopyImageError,
  143    147   
            >::new());
  144    148   
  145    149   
        ::std::borrow::Cow::Owned(rcb)
  146    150   
    }
  147    151   
}
  148    152   
  149    153   
#[derive(Debug)]
  150    154   
struct CopyImageResponseDeserializer;
  151    155   
impl ::aws_smithy_runtime_api::client::ser_de::DeserializeResponse for CopyImageResponseDeserializer {
  152         -
    fn deserialize_nonstreaming(
         156  +
    fn deserialize_nonstreaming_with_config(
  153    157   
        &self,
  154    158   
        response: &::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
         159  +
        _cfg: &::aws_smithy_types::config_bag::ConfigBag,
  155    160   
    ) -> ::aws_smithy_runtime_api::client::interceptors::context::OutputOrError {
  156    161   
        let (success, status) = (response.status().is_success(), response.status().as_u16());
  157    162   
        let headers = response.headers();
  158    163   
        let body = response.body().bytes().expect("body loaded");
  159    164   
        #[allow(unused_mut)]
  160    165   
        let mut force_error = false;
  161    166   
        ::tracing::debug!(request_id = ?::aws_types::request_id::RequestId::request_id(response));
  162    167   
        let parse_result = if !success && status != 200 || force_error {
  163    168   
            crate::protocol_serde::shape_copy_image::de_copy_image_http_error(status, headers, body)
  164    169   
        } else {

tmp-codegen-diff/aws-sdk/sdk/ec2/src/operation/copy_image/_copy_image_input.rs

@@ -158,158 +351,351 @@
  178    178   
    "com.amazonaws.ec2.synthetic",
  179    179   
    "CopyImageInput",
  180    180   
);
  181    181   
static COPYIMAGEINPUT_MEMBER_CLIENT_TOKEN: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  182    182   
    ::aws_smithy_schema::ShapeId::from_static(
  183    183   
        "com.amazonaws.ec2.synthetic#CopyImageInput$ClientToken",
  184    184   
        "com.amazonaws.ec2.synthetic",
  185    185   
        "CopyImageInput",
  186    186   
    ),
  187    187   
    ::aws_smithy_schema::ShapeType::String,
  188         -
    "client_token",
         188  +
    "ClientToken",
  189    189   
    0,
  190    190   
);
  191    191   
static COPYIMAGEINPUT_MEMBER_DESCRIPTION: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  192    192   
    ::aws_smithy_schema::ShapeId::from_static(
  193    193   
        "com.amazonaws.ec2.synthetic#CopyImageInput$Description",
  194    194   
        "com.amazonaws.ec2.synthetic",
  195    195   
        "CopyImageInput",
  196    196   
    ),
  197    197   
    ::aws_smithy_schema::ShapeType::String,
  198         -
    "description",
         198  +
    "Description",
  199    199   
    1,
  200    200   
);
  201    201   
static COPYIMAGEINPUT_MEMBER_ENCRYPTED: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  202    202   
    ::aws_smithy_schema::ShapeId::from_static(
  203    203   
        "com.amazonaws.ec2.synthetic#CopyImageInput$Encrypted",
  204    204   
        "com.amazonaws.ec2.synthetic",
  205    205   
        "CopyImageInput",
  206    206   
    ),
  207    207   
    ::aws_smithy_schema::ShapeType::Boolean,
  208         -
    "encrypted",
         208  +
    "Encrypted",
  209    209   
    2,
  210    210   
)
  211    211   
.with_xml_name("encrypted");
  212    212   
static COPYIMAGEINPUT_MEMBER_KMS_KEY_ID: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  213    213   
    ::aws_smithy_schema::ShapeId::from_static(
  214    214   
        "com.amazonaws.ec2.synthetic#CopyImageInput$KmsKeyId",
  215    215   
        "com.amazonaws.ec2.synthetic",
  216    216   
        "CopyImageInput",
  217    217   
    ),
  218    218   
    ::aws_smithy_schema::ShapeType::String,
  219         -
    "kms_key_id",
         219  +
    "KmsKeyId",
  220    220   
    3,
  221    221   
)
  222    222   
.with_xml_name("kmsKeyId");
  223    223   
static COPYIMAGEINPUT_MEMBER_NAME: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  224    224   
    ::aws_smithy_schema::ShapeId::from_static(
  225    225   
        "com.amazonaws.ec2.synthetic#CopyImageInput$Name",
  226    226   
        "com.amazonaws.ec2.synthetic",
  227    227   
        "CopyImageInput",
  228    228   
    ),
  229    229   
    ::aws_smithy_schema::ShapeType::String,
  230         -
    "name",
         230  +
    "Name",
  231    231   
    4,
  232    232   
);
  233    233   
static COPYIMAGEINPUT_MEMBER_SOURCE_IMAGE_ID: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  234    234   
    ::aws_smithy_schema::ShapeId::from_static(
  235    235   
        "com.amazonaws.ec2.synthetic#CopyImageInput$SourceImageId",
  236    236   
        "com.amazonaws.ec2.synthetic",
  237    237   
        "CopyImageInput",
  238    238   
    ),
  239    239   
    ::aws_smithy_schema::ShapeType::String,
  240         -
    "source_image_id",
         240  +
    "SourceImageId",
  241    241   
    5,
  242    242   
);
  243    243   
static COPYIMAGEINPUT_MEMBER_SOURCE_REGION: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  244    244   
    ::aws_smithy_schema::ShapeId::from_static(
  245    245   
        "com.amazonaws.ec2.synthetic#CopyImageInput$SourceRegion",
  246    246   
        "com.amazonaws.ec2.synthetic",
  247    247   
        "CopyImageInput",
  248    248   
    ),
  249    249   
    ::aws_smithy_schema::ShapeType::String,
  250         -
    "source_region",
         250  +
    "SourceRegion",
  251    251   
    6,
  252    252   
);
  253    253   
static COPYIMAGEINPUT_MEMBER_DESTINATION_OUTPOST_ARN: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  254    254   
    ::aws_smithy_schema::ShapeId::from_static(
  255    255   
        "com.amazonaws.ec2.synthetic#CopyImageInput$DestinationOutpostArn",
  256    256   
        "com.amazonaws.ec2.synthetic",
  257    257   
        "CopyImageInput",
  258    258   
    ),
  259    259   
    ::aws_smithy_schema::ShapeType::String,
  260         -
    "destination_outpost_arn",
         260  +
    "DestinationOutpostArn",
  261    261   
    7,
  262    262   
);
  263    263   
static COPYIMAGEINPUT_MEMBER_COPY_IMAGE_TAGS: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  264    264   
    ::aws_smithy_schema::ShapeId::from_static(
  265    265   
        "com.amazonaws.ec2.synthetic#CopyImageInput$CopyImageTags",
  266    266   
        "com.amazonaws.ec2.synthetic",
  267    267   
        "CopyImageInput",
  268    268   
    ),
  269    269   
    ::aws_smithy_schema::ShapeType::Boolean,
  270         -
    "copy_image_tags",
         270  +
    "CopyImageTags",
  271    271   
    8,
  272    272   
);
  273    273   
static COPYIMAGEINPUT_MEMBER_TAG_SPECIFICATIONS: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  274    274   
    ::aws_smithy_schema::ShapeId::from_static(
  275    275   
        "com.amazonaws.ec2.synthetic#CopyImageInput$TagSpecifications",
  276    276   
        "com.amazonaws.ec2.synthetic",
  277    277   
        "CopyImageInput",
  278    278   
    ),
  279    279   
    ::aws_smithy_schema::ShapeType::List,
  280         -
    "tag_specifications",
         280  +
    "TagSpecifications",
  281    281   
    9,
  282    282   
)
  283    283   
.with_xml_name("TagSpecification");
  284    284   
static COPYIMAGEINPUT_MEMBER_SNAPSHOT_COPY_COMPLETION_DURATION_MINUTES: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  285    285   
    ::aws_smithy_schema::ShapeId::from_static(
  286    286   
        "com.amazonaws.ec2.synthetic#CopyImageInput$SnapshotCopyCompletionDurationMinutes",
  287    287   
        "com.amazonaws.ec2.synthetic",
  288    288   
        "CopyImageInput",
  289    289   
    ),
  290    290   
    ::aws_smithy_schema::ShapeType::Long,
  291         -
    "snapshot_copy_completion_duration_minutes",
         291  +
    "SnapshotCopyCompletionDurationMinutes",
  292    292   
    10,
  293    293   
);
  294    294   
static COPYIMAGEINPUT_MEMBER_DESTINATION_AVAILABILITY_ZONE: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  295    295   
    ::aws_smithy_schema::ShapeId::from_static(
  296    296   
        "com.amazonaws.ec2.synthetic#CopyImageInput$DestinationAvailabilityZone",
  297    297   
        "com.amazonaws.ec2.synthetic",
  298    298   
        "CopyImageInput",
  299    299   
    ),
  300    300   
    ::aws_smithy_schema::ShapeType::String,
  301         -
    "destination_availability_zone",
         301  +
    "DestinationAvailabilityZone",
  302    302   
    11,
  303    303   
);
  304    304   
static COPYIMAGEINPUT_MEMBER_DESTINATION_AVAILABILITY_ZONE_ID: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  305    305   
    ::aws_smithy_schema::ShapeId::from_static(
  306    306   
        "com.amazonaws.ec2.synthetic#CopyImageInput$DestinationAvailabilityZoneId",
  307    307   
        "com.amazonaws.ec2.synthetic",
  308    308   
        "CopyImageInput",
  309    309   
    ),
  310    310   
    ::aws_smithy_schema::ShapeType::String,
  311         -
    "destination_availability_zone_id",
         311  +
    "DestinationAvailabilityZoneId",
  312    312   
    12,
  313    313   
);
  314    314   
static COPYIMAGEINPUT_MEMBER_DRY_RUN: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  315    315   
    ::aws_smithy_schema::ShapeId::from_static(
  316    316   
        "com.amazonaws.ec2.synthetic#CopyImageInput$DryRun",
  317    317   
        "com.amazonaws.ec2.synthetic",
  318    318   
        "CopyImageInput",
  319    319   
    ),
  320    320   
    ::aws_smithy_schema::ShapeType::Boolean,
  321         -
    "dry_run",
         321  +
    "DryRun",
  322    322   
    13,
  323    323   
)
  324    324   
.with_xml_name("dryRun");
  325    325   
static COPYIMAGEINPUT_SCHEMA: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_struct(
  326    326   
    COPYIMAGEINPUT_SCHEMA_ID,
  327    327   
    ::aws_smithy_schema::ShapeType::Structure,
  328    328   
    &[
  329    329   
        &COPYIMAGEINPUT_MEMBER_CLIENT_TOKEN,
  330    330   
        &COPYIMAGEINPUT_MEMBER_DESCRIPTION,
  331    331   
        &COPYIMAGEINPUT_MEMBER_ENCRYPTED,
@@ -380,380 +514,525 @@
  400    400   
            ser.write_string(&COPYIMAGEINPUT_MEMBER_DESTINATION_AVAILABILITY_ZONE_ID, val)?;
  401    401   
        }
  402    402   
        if let Some(ref val) = self.dry_run {
  403    403   
            ser.write_boolean(&COPYIMAGEINPUT_MEMBER_DRY_RUN, *val)?;
  404    404   
        }
  405    405   
        Ok(())
  406    406   
    }
  407    407   
}
  408    408   
impl CopyImageInput {
  409    409   
    /// Deserializes this structure from a [`ShapeDeserializer`].
  410         -
    pub fn deserialize<D: ::aws_smithy_schema::serde::ShapeDeserializer>(
  411         -
        deserializer: &mut D,
         410  +
    pub fn deserialize(
         411  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
  412    412   
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
  413    413   
        #[allow(unused_variables, unused_mut)]
  414    414   
        let mut builder = Self::builder();
  415    415   
        #[allow(
  416    416   
            unused_variables,
  417    417   
            unreachable_code,
  418    418   
            clippy::single_match,
  419    419   
            clippy::match_single_binding,
  420    420   
            clippy::diverging_sub_expression
  421    421   
        )]
  422         -
        deserializer.read_struct(&COPYIMAGEINPUT_SCHEMA, (), |_, member, deser| {
         422  +
        deserializer.read_struct(&COPYIMAGEINPUT_SCHEMA, &mut |member, deser| {
  423    423   
            match member.member_index() {
  424    424   
                Some(0) => {
  425    425   
                    builder.client_token = Some(deser.read_string(member)?);
  426    426   
                }
  427    427   
                Some(1) => {
  428    428   
                    builder.description = Some(deser.read_string(member)?);
  429    429   
                }
  430    430   
                Some(2) => {
  431    431   
                    builder.encrypted = Some(deser.read_boolean(member)?);
  432    432   
                }
  433    433   
                Some(3) => {
  434    434   
                    builder.kms_key_id = Some(deser.read_string(member)?);
  435    435   
                }
  436    436   
                Some(4) => {
  437    437   
                    builder.name = Some(deser.read_string(member)?);
  438    438   
                }
  439    439   
                Some(5) => {
  440    440   
                    builder.source_image_id = Some(deser.read_string(member)?);
  441    441   
                }
  442    442   
                Some(6) => {
  443    443   
                    builder.source_region = Some(deser.read_string(member)?);
  444    444   
                }
  445    445   
                Some(7) => {
  446    446   
                    builder.destination_outpost_arn = Some(deser.read_string(member)?);
  447    447   
                }
  448    448   
                Some(8) => {
  449    449   
                    builder.copy_image_tags = Some(deser.read_boolean(member)?);
  450    450   
                }
  451    451   
                Some(9) => {
  452    452   
                    builder.tag_specifications = Some({
  453         -
                        let container = if let Some(cap) = deser.container_size() {
  454         -
                            Vec::with_capacity(cap)
  455         -
                        } else {
  456         -
                            Vec::new()
  457         -
                        };
  458         -
                        deser.read_list(member, container, |mut list, deser| {
  459         -
                            list.push(crate::types::TagSpecification::deserialize(deser)?);
  460         -
                            Ok(list)
  461         -
                        })?
         453  +
                        let mut container = Vec::new();
         454  +
                        deser.read_list(member, &mut |deser| {
         455  +
                            container.push(crate::types::TagSpecification::deserialize(deser)?);
         456  +
                            Ok(())
         457  +
                        })?;
         458  +
                        container
  462    459   
                    });
  463    460   
                }
  464    461   
                Some(10) => {
  465    462   
                    builder.snapshot_copy_completion_duration_minutes = Some(deser.read_long(member)?);
  466    463   
                }
  467    464   
                Some(11) => {
  468    465   
                    builder.destination_availability_zone = Some(deser.read_string(member)?);
  469    466   
                }
  470    467   
                Some(12) => {
  471    468   
                    builder.destination_availability_zone_id = Some(deser.read_string(member)?);
  472    469   
                }
  473    470   
                Some(13) => {
  474    471   
                    builder.dry_run = Some(deser.read_boolean(member)?);
  475    472   
                }
  476    473   
                _ => {}
  477    474   
            }
  478    475   
            Ok(())
  479    476   
        })?;
         477  +
        builder.name = builder.name.or(Some(String::new()));
         478  +
        builder.source_image_id = builder.source_image_id.or(Some(String::new()));
         479  +
        builder.source_region = builder.source_region.or(Some(String::new()));
  480    480   
        builder
  481    481   
            .build()
  482    482   
            .map_err(|e| aws_smithy_schema::serde::SerdeError::Custom { message: e.to_string() })
  483    483   
    }
  484    484   
}
         485  +
impl CopyImageInput {
         486  +
    /// Deserializes this structure from a body deserializer and HTTP response.
         487  +
    pub fn deserialize_with_response(
         488  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
         489  +
        _headers: &::aws_smithy_runtime_api::http::Headers,
         490  +
        _status: u16,
         491  +
        _body: &[u8],
         492  +
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
         493  +
        Self::deserialize(deserializer)
         494  +
    }
         495  +
}
  485    496   
impl CopyImageInput {
  486    497   
    /// Creates a new builder-style object to manufacture [`CopyImageInput`](crate::operation::copy_image::CopyImageInput).
  487    498   
    pub fn builder() -> crate::operation::copy_image::builders::CopyImageInputBuilder {
  488    499   
        crate::operation::copy_image::builders::CopyImageInputBuilder::default()
  489    500   
    }
  490    501   
}
  491    502   
  492    503   
/// A builder for [`CopyImageInput`](crate::operation::copy_image::CopyImageInput).
  493    504   
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
  494    505   
#[non_exhaustive]

tmp-codegen-diff/aws-sdk/sdk/ec2/src/operation/copy_image/_copy_image_output.rs

@@ -1,1 +98,142 @@
   19     19   
    "com.amazonaws.ec2.synthetic",
   20     20   
    "CopyImageOutput",
   21     21   
);
   22     22   
static COPYIMAGEOUTPUT_MEMBER_IMAGE_ID: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
   23     23   
    ::aws_smithy_schema::ShapeId::from_static(
   24     24   
        "com.amazonaws.ec2.synthetic#CopyImageOutput$ImageId",
   25     25   
        "com.amazonaws.ec2.synthetic",
   26     26   
        "CopyImageOutput",
   27     27   
    ),
   28     28   
    ::aws_smithy_schema::ShapeType::String,
   29         -
    "image_id",
          29  +
    "ImageId",
   30     30   
    0,
   31     31   
)
   32     32   
.with_xml_name("imageId");
          33  +
static COPYIMAGEOUTPUT_MEMBER__REQUEST_ID: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
          34  +
    ::aws_smithy_schema::ShapeId::from_static("synthetic#request_id", "synthetic", "request_id"),
          35  +
    ::aws_smithy_schema::ShapeType::String,
          36  +
    "request_id",
          37  +
    1,
          38  +
)
          39  +
.with_http_header("x-amzn-requestid");
   33     40   
static COPYIMAGEOUTPUT_SCHEMA: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_struct(
   34     41   
    COPYIMAGEOUTPUT_SCHEMA_ID,
   35     42   
    ::aws_smithy_schema::ShapeType::Structure,
   36         -
    &[&COPYIMAGEOUTPUT_MEMBER_IMAGE_ID],
          43  +
    &[&COPYIMAGEOUTPUT_MEMBER_IMAGE_ID, &COPYIMAGEOUTPUT_MEMBER__REQUEST_ID],
   37     44   
);
   38     45   
impl CopyImageOutput {
   39     46   
    /// The schema for this shape.
   40     47   
    pub const SCHEMA: &'static ::aws_smithy_schema::Schema = &COPYIMAGEOUTPUT_SCHEMA;
   41     48   
}
   42     49   
impl ::aws_smithy_schema::serde::SerializableStruct for CopyImageOutput {
   43     50   
    #[allow(unused_variables, clippy::diverging_sub_expression)]
   44     51   
    fn serialize_members(
   45     52   
        &self,
   46     53   
        ser: &mut dyn ::aws_smithy_schema::serde::ShapeSerializer,
   47     54   
    ) -> ::std::result::Result<(), ::aws_smithy_schema::serde::SerdeError> {
   48     55   
        if let Some(ref val) = self.image_id {
   49     56   
            ser.write_string(&COPYIMAGEOUTPUT_MEMBER_IMAGE_ID, val)?;
   50     57   
        }
   51     58   
        Ok(())
   52     59   
    }
   53     60   
}
   54     61   
impl CopyImageOutput {
   55     62   
    /// Deserializes this structure from a [`ShapeDeserializer`].
   56         -
    pub fn deserialize<D: ::aws_smithy_schema::serde::ShapeDeserializer>(
   57         -
        deserializer: &mut D,
          63  +
    pub fn deserialize(
          64  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
          65  +
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
          66  +
        #[allow(unused_variables, unused_mut)]
          67  +
        let mut builder = Self::builder();
          68  +
        #[allow(
          69  +
            unused_variables,
          70  +
            unreachable_code,
          71  +
            clippy::single_match,
          72  +
            clippy::match_single_binding,
          73  +
            clippy::diverging_sub_expression
          74  +
        )]
          75  +
        deserializer.read_struct(&COPYIMAGEOUTPUT_SCHEMA, &mut |member, deser| {
          76  +
            match member.member_index() {
          77  +
                Some(0) => {
          78  +
                    builder.image_id = Some(deser.read_string(member)?);
          79  +
                }
          80  +
                Some(1) => {
          81  +
                    builder._request_id = Some(deser.read_string(member)?);
          82  +
                }
          83  +
                _ => {}
          84  +
            }
          85  +
            Ok(())
          86  +
        })?;
          87  +
        Ok(builder.build())
          88  +
    }
          89  +
}
          90  +
impl CopyImageOutput {
          91  +
    /// Deserializes this structure from a body deserializer and HTTP response headers.
          92  +
    /// Header-bound members are read directly from headers, avoiding runtime
          93  +
    /// member iteration overhead. Body members are read via the deserializer.
          94  +
    pub fn deserialize_with_response(
          95  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
          96  +
        headers: &::aws_smithy_runtime_api::http::Headers,
          97  +
        _status: u16,
          98  +
        _body: &[u8],
   58     99   
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
   59    100   
        #[allow(unused_variables, unused_mut)]
   60    101   
        let mut builder = Self::builder();
         102  +
        if let Some(val) = headers.get("x-amzn-requestid") {
         103  +
            builder._request_id = Some(val.to_string());
         104  +
        }
   61    105   
        #[allow(
   62    106   
            unused_variables,
   63    107   
            unreachable_code,
   64    108   
            clippy::single_match,
   65    109   
            clippy::match_single_binding,
   66    110   
            clippy::diverging_sub_expression
   67    111   
        )]
   68         -
        deserializer.read_struct(&COPYIMAGEOUTPUT_SCHEMA, (), |_, member, deser| {
         112  +
        deserializer.read_struct(&COPYIMAGEOUTPUT_SCHEMA, &mut |member, deser| {
   69    113   
            match member.member_index() {
   70    114   
                Some(0) => {
   71    115   
                    builder.image_id = Some(deser.read_string(member)?);
   72    116   
                }
   73    117   
                _ => {}
   74    118   
            }
   75    119   
            Ok(())
   76    120   
        })?;
   77    121   
        Ok(builder.build())
   78    122   
    }

tmp-codegen-diff/aws-sdk/sdk/ec2/src/operation/copy_snapshot.rs

@@ -1,1 +40,44 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
    2      2   
/// Orchestration and serialization glue logic for `CopySnapshot`.
    3      3   
#[derive(::std::clone::Clone, ::std::default::Default, ::std::fmt::Debug)]
    4      4   
#[non_exhaustive]
    5      5   
pub struct CopySnapshot;
    6      6   
impl CopySnapshot {
    7      7   
    /// Creates a new `CopySnapshot`
    8      8   
    pub fn new() -> Self {
    9      9   
        Self
   10     10   
    }
          11  +
    /// The schema for this operation's input shape.
          12  +
    pub const INPUT_SCHEMA: &'static ::aws_smithy_schema::Schema = crate::operation::copy_snapshot::CopySnapshotInput::SCHEMA;
          13  +
    /// The schema for this operation's output shape.
          14  +
    pub const OUTPUT_SCHEMA: &'static ::aws_smithy_schema::Schema = crate::operation::copy_snapshot::CopySnapshotOutput::SCHEMA;
   11     15   
    pub(crate) async fn orchestrate(
   12     16   
        runtime_plugins: &::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins,
   13     17   
        input: crate::operation::copy_snapshot::CopySnapshotInput,
   14     18   
    ) -> ::std::result::Result<
   15     19   
        crate::operation::copy_snapshot::CopySnapshotOutput,
   16     20   
        ::aws_smithy_runtime_api::client::result::SdkError<
   17     21   
            crate::operation::copy_snapshot::CopySnapshotError,
   18     22   
            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
   19     23   
        >,
   20     24   
    > {
@@ -115,119 +177,182 @@
  135    139   
                crate::operation::copy_snapshot::CopySnapshotError,
  136    140   
            >::new());
  137    141   
  138    142   
        ::std::borrow::Cow::Owned(rcb)
  139    143   
    }
  140    144   
}
  141    145   
  142    146   
#[derive(Debug)]
  143    147   
struct CopySnapshotResponseDeserializer;
  144    148   
impl ::aws_smithy_runtime_api::client::ser_de::DeserializeResponse for CopySnapshotResponseDeserializer {
  145         -
    fn deserialize_nonstreaming(
         149  +
    fn deserialize_nonstreaming_with_config(
  146    150   
        &self,
  147    151   
        response: &::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
         152  +
        _cfg: &::aws_smithy_types::config_bag::ConfigBag,
  148    153   
    ) -> ::aws_smithy_runtime_api::client::interceptors::context::OutputOrError {
  149    154   
        let (success, status) = (response.status().is_success(), response.status().as_u16());
  150    155   
        let headers = response.headers();
  151    156   
        let body = response.body().bytes().expect("body loaded");
  152    157   
        #[allow(unused_mut)]
  153    158   
        let mut force_error = false;
  154    159   
        ::tracing::debug!(request_id = ?::aws_types::request_id::RequestId::request_id(response));
  155    160   
        let parse_result = if !success && status != 200 || force_error {
  156    161   
            crate::protocol_serde::shape_copy_snapshot::de_copy_snapshot_http_error(status, headers, body)
  157    162   
        } else {

tmp-codegen-diff/aws-sdk/sdk/ec2/src/operation/copy_snapshot/_copy_snapshot_input.rs

@@ -129,129 +304,304 @@
  149    149   
    "com.amazonaws.ec2.synthetic",
  150    150   
    "CopySnapshotInput",
  151    151   
);
  152    152   
static COPYSNAPSHOTINPUT_MEMBER_DESCRIPTION: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  153    153   
    ::aws_smithy_schema::ShapeId::from_static(
  154    154   
        "com.amazonaws.ec2.synthetic#CopySnapshotInput$Description",
  155    155   
        "com.amazonaws.ec2.synthetic",
  156    156   
        "CopySnapshotInput",
  157    157   
    ),
  158    158   
    ::aws_smithy_schema::ShapeType::String,
  159         -
    "description",
         159  +
    "Description",
  160    160   
    0,
  161    161   
);
  162    162   
static COPYSNAPSHOTINPUT_MEMBER_DESTINATION_OUTPOST_ARN: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  163    163   
    ::aws_smithy_schema::ShapeId::from_static(
  164    164   
        "com.amazonaws.ec2.synthetic#CopySnapshotInput$DestinationOutpostArn",
  165    165   
        "com.amazonaws.ec2.synthetic",
  166    166   
        "CopySnapshotInput",
  167    167   
    ),
  168    168   
    ::aws_smithy_schema::ShapeType::String,
  169         -
    "destination_outpost_arn",
         169  +
    "DestinationOutpostArn",
  170    170   
    1,
  171    171   
);
  172    172   
static COPYSNAPSHOTINPUT_MEMBER_DESTINATION_REGION: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  173    173   
    ::aws_smithy_schema::ShapeId::from_static(
  174    174   
        "com.amazonaws.ec2.synthetic#CopySnapshotInput$DestinationRegion",
  175    175   
        "com.amazonaws.ec2.synthetic",
  176    176   
        "CopySnapshotInput",
  177    177   
    ),
  178    178   
    ::aws_smithy_schema::ShapeType::String,
  179         -
    "destination_region",
         179  +
    "DestinationRegion",
  180    180   
    2,
  181    181   
)
  182    182   
.with_xml_name("destinationRegion");
  183    183   
static COPYSNAPSHOTINPUT_MEMBER_ENCRYPTED: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  184    184   
    ::aws_smithy_schema::ShapeId::from_static(
  185    185   
        "com.amazonaws.ec2.synthetic#CopySnapshotInput$Encrypted",
  186    186   
        "com.amazonaws.ec2.synthetic",
  187    187   
        "CopySnapshotInput",
  188    188   
    ),
  189    189   
    ::aws_smithy_schema::ShapeType::Boolean,
  190         -
    "encrypted",
         190  +
    "Encrypted",
  191    191   
    3,
  192    192   
)
  193    193   
.with_xml_name("encrypted");
  194    194   
static COPYSNAPSHOTINPUT_MEMBER_KMS_KEY_ID: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  195    195   
    ::aws_smithy_schema::ShapeId::from_static(
  196    196   
        "com.amazonaws.ec2.synthetic#CopySnapshotInput$KmsKeyId",
  197    197   
        "com.amazonaws.ec2.synthetic",
  198    198   
        "CopySnapshotInput",
  199    199   
    ),
  200    200   
    ::aws_smithy_schema::ShapeType::String,
  201         -
    "kms_key_id",
         201  +
    "KmsKeyId",
  202    202   
    4,
  203    203   
)
  204    204   
.with_xml_name("kmsKeyId");
  205    205   
static COPYSNAPSHOTINPUT_MEMBER_PRESIGNED_URL: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  206    206   
    ::aws_smithy_schema::ShapeId::from_static(
  207    207   
        "com.amazonaws.ec2.synthetic#CopySnapshotInput$PresignedUrl",
  208    208   
        "com.amazonaws.ec2.synthetic",
  209    209   
        "CopySnapshotInput",
  210    210   
    ),
  211    211   
    ::aws_smithy_schema::ShapeType::String,
  212         -
    "presigned_url",
         212  +
    "PresignedUrl",
  213    213   
    5,
  214    214   
)
  215    215   
.with_xml_name("presignedUrl");
  216    216   
static COPYSNAPSHOTINPUT_MEMBER_SOURCE_REGION: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  217    217   
    ::aws_smithy_schema::ShapeId::from_static(
  218    218   
        "com.amazonaws.ec2.synthetic#CopySnapshotInput$SourceRegion",
  219    219   
        "com.amazonaws.ec2.synthetic",
  220    220   
        "CopySnapshotInput",
  221    221   
    ),
  222    222   
    ::aws_smithy_schema::ShapeType::String,
  223         -
    "source_region",
         223  +
    "SourceRegion",
  224    224   
    6,
  225    225   
);
  226    226   
static COPYSNAPSHOTINPUT_MEMBER_SOURCE_SNAPSHOT_ID: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  227    227   
    ::aws_smithy_schema::ShapeId::from_static(
  228    228   
        "com.amazonaws.ec2.synthetic#CopySnapshotInput$SourceSnapshotId",
  229    229   
        "com.amazonaws.ec2.synthetic",
  230    230   
        "CopySnapshotInput",
  231    231   
    ),
  232    232   
    ::aws_smithy_schema::ShapeType::String,
  233         -
    "source_snapshot_id",
         233  +
    "SourceSnapshotId",
  234    234   
    7,
  235    235   
);
  236    236   
static COPYSNAPSHOTINPUT_MEMBER_TAG_SPECIFICATIONS: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  237    237   
    ::aws_smithy_schema::ShapeId::from_static(
  238    238   
        "com.amazonaws.ec2.synthetic#CopySnapshotInput$TagSpecifications",
  239    239   
        "com.amazonaws.ec2.synthetic",
  240    240   
        "CopySnapshotInput",
  241    241   
    ),
  242    242   
    ::aws_smithy_schema::ShapeType::List,
  243         -
    "tag_specifications",
         243  +
    "TagSpecifications",
  244    244   
    8,
  245    245   
)
  246    246   
.with_xml_name("TagSpecification");
  247    247   
static COPYSNAPSHOTINPUT_MEMBER_COMPLETION_DURATION_MINUTES: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  248    248   
    ::aws_smithy_schema::ShapeId::from_static(
  249    249   
        "com.amazonaws.ec2.synthetic#CopySnapshotInput$CompletionDurationMinutes",
  250    250   
        "com.amazonaws.ec2.synthetic",
  251    251   
        "CopySnapshotInput",
  252    252   
    ),
  253    253   
    ::aws_smithy_schema::ShapeType::Integer,
  254         -
    "completion_duration_minutes",
         254  +
    "CompletionDurationMinutes",
  255    255   
    9,
  256    256   
);
  257    257   
static COPYSNAPSHOTINPUT_MEMBER_DESTINATION_AVAILABILITY_ZONE: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  258    258   
    ::aws_smithy_schema::ShapeId::from_static(
  259    259   
        "com.amazonaws.ec2.synthetic#CopySnapshotInput$DestinationAvailabilityZone",
  260    260   
        "com.amazonaws.ec2.synthetic",
  261    261   
        "CopySnapshotInput",
  262    262   
    ),
  263    263   
    ::aws_smithy_schema::ShapeType::String,
  264         -
    "destination_availability_zone",
         264  +
    "DestinationAvailabilityZone",
  265    265   
    10,
  266    266   
);
  267    267   
static COPYSNAPSHOTINPUT_MEMBER_DRY_RUN: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  268    268   
    ::aws_smithy_schema::ShapeId::from_static(
  269    269   
        "com.amazonaws.ec2.synthetic#CopySnapshotInput$DryRun",
  270    270   
        "com.amazonaws.ec2.synthetic",
  271    271   
        "CopySnapshotInput",
  272    272   
    ),
  273    273   
    ::aws_smithy_schema::ShapeType::Boolean,
  274         -
    "dry_run",
         274  +
    "DryRun",
  275    275   
    11,
  276    276   
)
  277    277   
.with_xml_name("dryRun");
  278    278   
static COPYSNAPSHOTINPUT_SCHEMA: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_struct(
  279    279   
    COPYSNAPSHOTINPUT_SCHEMA_ID,
  280    280   
    ::aws_smithy_schema::ShapeType::Structure,
  281    281   
    &[
  282    282   
        &COPYSNAPSHOTINPUT_MEMBER_DESCRIPTION,
  283    283   
        &COPYSNAPSHOTINPUT_MEMBER_DESTINATION_OUTPOST_ARN,
  284    284   
        &COPYSNAPSHOTINPUT_MEMBER_DESTINATION_REGION,
@@ -325,325 +453,463 @@
  345    345   
            ser.write_string(&COPYSNAPSHOTINPUT_MEMBER_DESTINATION_AVAILABILITY_ZONE, val)?;
  346    346   
        }
  347    347   
        if let Some(ref val) = self.dry_run {
  348    348   
            ser.write_boolean(&COPYSNAPSHOTINPUT_MEMBER_DRY_RUN, *val)?;
  349    349   
        }
  350    350   
        Ok(())
  351    351   
    }
  352    352   
}
  353    353   
impl CopySnapshotInput {
  354    354   
    /// Deserializes this structure from a [`ShapeDeserializer`].
  355         -
    pub fn deserialize<D: ::aws_smithy_schema::serde::ShapeDeserializer>(
  356         -
        deserializer: &mut D,
         355  +
    pub fn deserialize(
         356  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
  357    357   
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
  358    358   
        #[allow(unused_variables, unused_mut)]
  359    359   
        let mut builder = Self::builder();
  360    360   
        #[allow(
  361    361   
            unused_variables,
  362    362   
            unreachable_code,
  363    363   
            clippy::single_match,
  364    364   
            clippy::match_single_binding,
  365    365   
            clippy::diverging_sub_expression
  366    366   
        )]
  367         -
        deserializer.read_struct(&COPYSNAPSHOTINPUT_SCHEMA, (), |_, member, deser| {
         367  +
        deserializer.read_struct(&COPYSNAPSHOTINPUT_SCHEMA, &mut |member, deser| {
  368    368   
            match member.member_index() {
  369    369   
                Some(0) => {
  370    370   
                    builder.description = Some(deser.read_string(member)?);
  371    371   
                }
  372    372   
                Some(1) => {
  373    373   
                    builder.destination_outpost_arn = Some(deser.read_string(member)?);
  374    374   
                }
  375    375   
                Some(2) => {
  376    376   
                    builder.destination_region = Some(deser.read_string(member)?);
  377    377   
                }
  378    378   
                Some(3) => {
  379    379   
                    builder.encrypted = Some(deser.read_boolean(member)?);
  380    380   
                }
  381    381   
                Some(4) => {
  382    382   
                    builder.kms_key_id = Some(deser.read_string(member)?);
  383    383   
                }
  384    384   
                Some(5) => {
  385    385   
                    builder.presigned_url = Some(deser.read_string(member)?);
  386    386   
                }
  387    387   
                Some(6) => {
  388    388   
                    builder.source_region = Some(deser.read_string(member)?);
  389    389   
                }
  390    390   
                Some(7) => {
  391    391   
                    builder.source_snapshot_id = Some(deser.read_string(member)?);
  392    392   
                }
  393    393   
                Some(8) => {
  394    394   
                    builder.tag_specifications = Some({
  395         -
                        let container = if let Some(cap) = deser.container_size() {
  396         -
                            Vec::with_capacity(cap)
  397         -
                        } else {
  398         -
                            Vec::new()
  399         -
                        };
  400         -
                        deser.read_list(member, container, |mut list, deser| {
  401         -
                            list.push(crate::types::TagSpecification::deserialize(deser)?);
  402         -
                            Ok(list)
  403         -
                        })?
         395  +
                        let mut container = Vec::new();
         396  +
                        deser.read_list(member, &mut |deser| {
         397  +
                            container.push(crate::types::TagSpecification::deserialize(deser)?);
         398  +
                            Ok(())
         399  +
                        })?;
         400  +
                        container
  404    401   
                    });
  405    402   
                }
  406    403   
                Some(9) => {
  407    404   
                    builder.completion_duration_minutes = Some(deser.read_integer(member)?);
  408    405   
                }
  409    406   
                Some(10) => {
  410    407   
                    builder.destination_availability_zone = Some(deser.read_string(member)?);
  411    408   
                }
  412    409   
                Some(11) => {
  413    410   
                    builder.dry_run = Some(deser.read_boolean(member)?);
  414    411   
                }
  415    412   
                _ => {}
  416    413   
            }
  417    414   
            Ok(())
  418    415   
        })?;
         416  +
        builder.source_region = builder.source_region.or(Some(String::new()));
         417  +
        builder.source_snapshot_id = builder.source_snapshot_id.or(Some(String::new()));
  419    418   
        builder
  420    419   
            .build()
  421    420   
            .map_err(|e| aws_smithy_schema::serde::SerdeError::Custom { message: e.to_string() })
  422    421   
    }
  423    422   
}
         423  +
impl CopySnapshotInput {
         424  +
    /// Deserializes this structure from a body deserializer and HTTP response.
         425  +
    pub fn deserialize_with_response(
         426  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
         427  +
        _headers: &::aws_smithy_runtime_api::http::Headers,
         428  +
        _status: u16,
         429  +
        _body: &[u8],
         430  +
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
         431  +
        Self::deserialize(deserializer)
         432  +
    }
         433  +
}
  424    434   
impl CopySnapshotInput {
  425    435   
    /// Creates a new builder-style object to manufacture [`CopySnapshotInput`](crate::operation::copy_snapshot::CopySnapshotInput).
  426    436   
    pub fn builder() -> crate::operation::copy_snapshot::builders::CopySnapshotInputBuilder {
  427    437   
        crate::operation::copy_snapshot::builders::CopySnapshotInputBuilder::default()
  428    438   
    }
  429    439   
}
  430    440   
  431    441   
/// A builder for [`CopySnapshotInput`](crate::operation::copy_snapshot::CopySnapshotInput).
  432    442   
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default)]
  433    443   
#[non_exhaustive]

tmp-codegen-diff/aws-sdk/sdk/ec2/src/operation/copy_snapshot/_copy_snapshot_output.rs

@@ -6,6 +139,194 @@
   26     26   
    "com.amazonaws.ec2.synthetic",
   27     27   
    "CopySnapshotOutput",
   28     28   
);
   29     29   
static COPYSNAPSHOTOUTPUT_MEMBER_TAGS: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
   30     30   
    ::aws_smithy_schema::ShapeId::from_static(
   31     31   
        "com.amazonaws.ec2.synthetic#CopySnapshotOutput$Tags",
   32     32   
        "com.amazonaws.ec2.synthetic",
   33     33   
        "CopySnapshotOutput",
   34     34   
    ),
   35     35   
    ::aws_smithy_schema::ShapeType::List,
   36         -
    "tags",
          36  +
    "Tags",
   37     37   
    0,
   38     38   
)
   39     39   
.with_xml_name("tagSet");
   40     40   
static COPYSNAPSHOTOUTPUT_MEMBER_SNAPSHOT_ID: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
   41     41   
    ::aws_smithy_schema::ShapeId::from_static(
   42     42   
        "com.amazonaws.ec2.synthetic#CopySnapshotOutput$SnapshotId",
   43     43   
        "com.amazonaws.ec2.synthetic",
   44     44   
        "CopySnapshotOutput",
   45     45   
    ),
   46     46   
    ::aws_smithy_schema::ShapeType::String,
   47         -
    "snapshot_id",
          47  +
    "SnapshotId",
   48     48   
    1,
   49     49   
)
   50     50   
.with_xml_name("snapshotId");
          51  +
static COPYSNAPSHOTOUTPUT_MEMBER__REQUEST_ID: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
          52  +
    ::aws_smithy_schema::ShapeId::from_static("synthetic#request_id", "synthetic", "request_id"),
          53  +
    ::aws_smithy_schema::ShapeType::String,
          54  +
    "request_id",
          55  +
    2,
          56  +
)
          57  +
.with_http_header("x-amzn-requestid");
   51     58   
static COPYSNAPSHOTOUTPUT_SCHEMA: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_struct(
   52     59   
    COPYSNAPSHOTOUTPUT_SCHEMA_ID,
   53     60   
    ::aws_smithy_schema::ShapeType::Structure,
   54         -
    &[&COPYSNAPSHOTOUTPUT_MEMBER_TAGS, &COPYSNAPSHOTOUTPUT_MEMBER_SNAPSHOT_ID],
          61  +
    &[
          62  +
        &COPYSNAPSHOTOUTPUT_MEMBER_TAGS,
          63  +
        &COPYSNAPSHOTOUTPUT_MEMBER_SNAPSHOT_ID,
          64  +
        &COPYSNAPSHOTOUTPUT_MEMBER__REQUEST_ID,
          65  +
    ],
   55     66   
);
   56     67   
impl CopySnapshotOutput {
   57     68   
    /// The schema for this shape.
   58     69   
    pub const SCHEMA: &'static ::aws_smithy_schema::Schema = &COPYSNAPSHOTOUTPUT_SCHEMA;
   59     70   
}
   60     71   
impl ::aws_smithy_schema::serde::SerializableStruct for CopySnapshotOutput {
   61     72   
    #[allow(unused_variables, clippy::diverging_sub_expression)]
   62     73   
    fn serialize_members(
   63     74   
        &self,
   64     75   
        ser: &mut dyn ::aws_smithy_schema::serde::ShapeSerializer,
   65     76   
    ) -> ::std::result::Result<(), ::aws_smithy_schema::serde::SerdeError> {
   66     77   
        if let Some(ref val) = self.tags {
   67     78   
            ser.write_list(
   68     79   
                &COPYSNAPSHOTOUTPUT_MEMBER_TAGS,
   69     80   
                &|ser: &mut dyn ::aws_smithy_schema::serde::ShapeSerializer| {
   70     81   
                    for item in val {
   71     82   
                        ser.write_struct(crate::types::Tag::SCHEMA, item)?;
   72     83   
                    }
   73     84   
                    Ok(())
   74     85   
                },
   75     86   
            )?;
   76     87   
        }
   77     88   
        if let Some(ref val) = self.snapshot_id {
   78     89   
            ser.write_string(&COPYSNAPSHOTOUTPUT_MEMBER_SNAPSHOT_ID, val)?;
   79     90   
        }
   80     91   
        Ok(())
   81     92   
    }
   82     93   
}
   83     94   
impl CopySnapshotOutput {
   84     95   
    /// Deserializes this structure from a [`ShapeDeserializer`].
   85         -
    pub fn deserialize<D: ::aws_smithy_schema::serde::ShapeDeserializer>(
   86         -
        deserializer: &mut D,
          96  +
    pub fn deserialize(
          97  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
   87     98   
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
   88     99   
        #[allow(unused_variables, unused_mut)]
   89    100   
        let mut builder = Self::builder();
   90    101   
        #[allow(
   91    102   
            unused_variables,
   92    103   
            unreachable_code,
   93    104   
            clippy::single_match,
   94    105   
            clippy::match_single_binding,
   95    106   
            clippy::diverging_sub_expression
   96    107   
        )]
   97         -
        deserializer.read_struct(&COPYSNAPSHOTOUTPUT_SCHEMA, (), |_, member, deser| {
         108  +
        deserializer.read_struct(&COPYSNAPSHOTOUTPUT_SCHEMA, &mut |member, deser| {
   98    109   
            match member.member_index() {
   99    110   
                Some(0) => {
  100    111   
                    builder.tags = Some({
  101         -
                        let container = if let Some(cap) = deser.container_size() {
  102         -
                            Vec::with_capacity(cap)
  103         -
                        } else {
  104         -
                            Vec::new()
  105         -
                        };
  106         -
                        deser.read_list(member, container, |mut list, deser| {
  107         -
                            list.push(crate::types::Tag::deserialize(deser)?);
  108         -
                            Ok(list)
  109         -
                        })?
         112  +
                        let mut container = Vec::new();
         113  +
                        deser.read_list(member, &mut |deser| {
         114  +
                            container.push(crate::types::Tag::deserialize(deser)?);
         115  +
                            Ok(())
         116  +
                        })?;
         117  +
                        container
         118  +
                    });
         119  +
                }
         120  +
                Some(1) => {
         121  +
                    builder.snapshot_id = Some(deser.read_string(member)?);
         122  +
                }
         123  +
                Some(2) => {
         124  +
                    builder._request_id = Some(deser.read_string(member)?);
         125  +
                }
         126  +
                _ => {}
         127  +
            }
         128  +
            Ok(())
         129  +
        })?;
         130  +
        Ok(builder.build())
         131  +
    }
         132  +
}
         133  +
impl CopySnapshotOutput {
         134  +
    /// Deserializes this structure from a body deserializer and HTTP response headers.
         135  +
    /// Header-bound members are read directly from headers, avoiding runtime
         136  +
    /// member iteration overhead. Body members are read via the deserializer.
         137  +
    pub fn deserialize_with_response(
         138  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
         139  +
        headers: &::aws_smithy_runtime_api::http::Headers,
         140  +
        _status: u16,
         141  +
        _body: &[u8],
         142  +
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
         143  +
        #[allow(unused_variables, unused_mut)]
         144  +
        let mut builder = Self::builder();
         145  +
        if let Some(val) = headers.get("x-amzn-requestid") {
         146  +
            builder._request_id = Some(val.to_string());
         147  +
        }
         148  +
        #[allow(
         149  +
            unused_variables,
         150  +
            unreachable_code,
         151  +
            clippy::single_match,
         152  +
            clippy::match_single_binding,
         153  +
            clippy::diverging_sub_expression
         154  +
        )]
         155  +
        deserializer.read_struct(&COPYSNAPSHOTOUTPUT_SCHEMA, &mut |member, deser| {
         156  +
            match member.member_index() {
         157  +
                Some(0) => {
         158  +
                    builder.tags = Some({
         159  +
                        let mut container = Vec::new();
         160  +
                        deser.read_list(member, &mut |deser| {
         161  +
                            container.push(crate::types::Tag::deserialize(deser)?);
         162  +
                            Ok(())
         163  +
                        })?;
         164  +
                        container
  110    165   
                    });
  111    166   
                }
  112    167   
                Some(1) => {
  113    168   
                    builder.snapshot_id = Some(deser.read_string(member)?);
  114    169   
                }
  115    170   
                _ => {}
  116    171   
            }
  117    172   
            Ok(())
  118    173   
        })?;
  119    174   
        Ok(builder.build())

tmp-codegen-diff/aws-sdk/sdk/ec2/src/operation/create_capacity_reservation.rs

@@ -1,1 +40,46 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
    2      2   
/// Orchestration and serialization glue logic for `CreateCapacityReservation`.
    3      3   
#[derive(::std::clone::Clone, ::std::default::Default, ::std::fmt::Debug)]
    4      4   
#[non_exhaustive]
    5      5   
pub struct CreateCapacityReservation;
    6      6   
impl CreateCapacityReservation {
    7      7   
    /// Creates a new `CreateCapacityReservation`
    8      8   
    pub fn new() -> Self {
    9      9   
        Self
   10     10   
    }
          11  +
    /// The schema for this operation's input shape.
          12  +
    pub const INPUT_SCHEMA: &'static ::aws_smithy_schema::Schema =
          13  +
        crate::operation::create_capacity_reservation::CreateCapacityReservationInput::SCHEMA;
          14  +
    /// The schema for this operation's output shape.
          15  +
    pub const OUTPUT_SCHEMA: &'static ::aws_smithy_schema::Schema =
          16  +
        crate::operation::create_capacity_reservation::CreateCapacityReservationOutput::SCHEMA;
   11     17   
    pub(crate) async fn orchestrate(
   12     18   
        runtime_plugins: &::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins,
   13     19   
        input: crate::operation::create_capacity_reservation::CreateCapacityReservationInput,
   14     20   
    ) -> ::std::result::Result<
   15     21   
        crate::operation::create_capacity_reservation::CreateCapacityReservationOutput,
   16     22   
        ::aws_smithy_runtime_api::client::result::SdkError<
   17     23   
            crate::operation::create_capacity_reservation::CreateCapacityReservationError,
   18     24   
            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
   19     25   
        >,
   20     26   
    > {
@@ -118,124 +180,187 @@
  138    144   
                crate::operation::create_capacity_reservation::CreateCapacityReservationError,
  139    145   
            >::new());
  140    146   
  141    147   
        ::std::borrow::Cow::Owned(rcb)
  142    148   
    }
  143    149   
}
  144    150   
  145    151   
#[derive(Debug)]
  146    152   
struct CreateCapacityReservationResponseDeserializer;
  147    153   
impl ::aws_smithy_runtime_api::client::ser_de::DeserializeResponse for CreateCapacityReservationResponseDeserializer {
  148         -
    fn deserialize_nonstreaming(
         154  +
    fn deserialize_nonstreaming_with_config(
  149    155   
        &self,
  150    156   
        response: &::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
         157  +
        _cfg: &::aws_smithy_types::config_bag::ConfigBag,
  151    158   
    ) -> ::aws_smithy_runtime_api::client::interceptors::context::OutputOrError {
  152    159   
        let (success, status) = (response.status().is_success(), response.status().as_u16());
  153    160   
        let headers = response.headers();
  154    161   
        let body = response.body().bytes().expect("body loaded");
  155    162   
        #[allow(unused_mut)]
  156    163   
        let mut force_error = false;
  157    164   
        ::tracing::debug!(request_id = ?::aws_types::request_id::RequestId::request_id(response));
  158    165   
        let parse_result = if !success && status != 200 || force_error {
  159    166   
            crate::protocol_serde::shape_create_capacity_reservation::de_create_capacity_reservation_http_error(status, headers, body)
  160    167   
        } else {

tmp-codegen-diff/aws-sdk/sdk/ec2/src/operation/create_capacity_reservation/_create_capacity_reservation_input.rs

@@ -205,205 +445,445 @@
  225    225   
    "com.amazonaws.ec2.synthetic",
  226    226   
    "CreateCapacityReservationInput",
  227    227   
);
  228    228   
static CREATECAPACITYRESERVATIONINPUT_MEMBER_CLIENT_TOKEN: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  229    229   
    ::aws_smithy_schema::ShapeId::from_static(
  230    230   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationInput$ClientToken",
  231    231   
        "com.amazonaws.ec2.synthetic",
  232    232   
        "CreateCapacityReservationInput",
  233    233   
    ),
  234    234   
    ::aws_smithy_schema::ShapeType::String,
  235         -
    "client_token",
         235  +
    "ClientToken",
  236    236   
    0,
  237    237   
);
  238    238   
static CREATECAPACITYRESERVATIONINPUT_MEMBER_INSTANCE_TYPE: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  239    239   
    ::aws_smithy_schema::ShapeId::from_static(
  240    240   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationInput$InstanceType",
  241    241   
        "com.amazonaws.ec2.synthetic",
  242    242   
        "CreateCapacityReservationInput",
  243    243   
    ),
  244    244   
    ::aws_smithy_schema::ShapeType::String,
  245         -
    "instance_type",
         245  +
    "InstanceType",
  246    246   
    1,
  247    247   
);
  248    248   
static CREATECAPACITYRESERVATIONINPUT_MEMBER_INSTANCE_PLATFORM: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  249    249   
    ::aws_smithy_schema::ShapeId::from_static(
  250    250   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationInput$InstancePlatform",
  251    251   
        "com.amazonaws.ec2.synthetic",
  252    252   
        "CreateCapacityReservationInput",
  253    253   
    ),
  254    254   
    ::aws_smithy_schema::ShapeType::String,
  255         -
    "instance_platform",
         255  +
    "InstancePlatform",
  256    256   
    2,
  257    257   
);
  258    258   
static CREATECAPACITYRESERVATIONINPUT_MEMBER_AVAILABILITY_ZONE: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  259    259   
    ::aws_smithy_schema::ShapeId::from_static(
  260    260   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationInput$AvailabilityZone",
  261    261   
        "com.amazonaws.ec2.synthetic",
  262    262   
        "CreateCapacityReservationInput",
  263    263   
    ),
  264    264   
    ::aws_smithy_schema::ShapeType::String,
  265         -
    "availability_zone",
         265  +
    "AvailabilityZone",
  266    266   
    3,
  267    267   
);
  268    268   
static CREATECAPACITYRESERVATIONINPUT_MEMBER_AVAILABILITY_ZONE_ID: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  269    269   
    ::aws_smithy_schema::ShapeId::from_static(
  270    270   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationInput$AvailabilityZoneId",
  271    271   
        "com.amazonaws.ec2.synthetic",
  272    272   
        "CreateCapacityReservationInput",
  273    273   
    ),
  274    274   
    ::aws_smithy_schema::ShapeType::String,
  275         -
    "availability_zone_id",
         275  +
    "AvailabilityZoneId",
  276    276   
    4,
  277    277   
);
  278    278   
static CREATECAPACITYRESERVATIONINPUT_MEMBER_TENANCY: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  279    279   
    ::aws_smithy_schema::ShapeId::from_static(
  280    280   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationInput$Tenancy",
  281    281   
        "com.amazonaws.ec2.synthetic",
  282    282   
        "CreateCapacityReservationInput",
  283    283   
    ),
  284    284   
    ::aws_smithy_schema::ShapeType::String,
  285         -
    "tenancy",
         285  +
    "Tenancy",
  286    286   
    5,
  287    287   
);
  288    288   
static CREATECAPACITYRESERVATIONINPUT_MEMBER_INSTANCE_COUNT: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  289    289   
    ::aws_smithy_schema::ShapeId::from_static(
  290    290   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationInput$InstanceCount",
  291    291   
        "com.amazonaws.ec2.synthetic",
  292    292   
        "CreateCapacityReservationInput",
  293    293   
    ),
  294    294   
    ::aws_smithy_schema::ShapeType::Integer,
  295         -
    "instance_count",
         295  +
    "InstanceCount",
  296    296   
    6,
  297    297   
);
  298    298   
static CREATECAPACITYRESERVATIONINPUT_MEMBER_EBS_OPTIMIZED: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  299    299   
    ::aws_smithy_schema::ShapeId::from_static(
  300    300   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationInput$EbsOptimized",
  301    301   
        "com.amazonaws.ec2.synthetic",
  302    302   
        "CreateCapacityReservationInput",
  303    303   
    ),
  304    304   
    ::aws_smithy_schema::ShapeType::Boolean,
  305         -
    "ebs_optimized",
         305  +
    "EbsOptimized",
  306    306   
    7,
  307    307   
);
  308    308   
static CREATECAPACITYRESERVATIONINPUT_MEMBER_EPHEMERAL_STORAGE: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  309    309   
    ::aws_smithy_schema::ShapeId::from_static(
  310    310   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationInput$EphemeralStorage",
  311    311   
        "com.amazonaws.ec2.synthetic",
  312    312   
        "CreateCapacityReservationInput",
  313    313   
    ),
  314    314   
    ::aws_smithy_schema::ShapeType::Boolean,
  315         -
    "ephemeral_storage",
         315  +
    "EphemeralStorage",
  316    316   
    8,
  317    317   
);
  318    318   
static CREATECAPACITYRESERVATIONINPUT_MEMBER_END_DATE: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  319    319   
    ::aws_smithy_schema::ShapeId::from_static(
  320    320   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationInput$EndDate",
  321    321   
        "com.amazonaws.ec2.synthetic",
  322    322   
        "CreateCapacityReservationInput",
  323    323   
    ),
  324    324   
    ::aws_smithy_schema::ShapeType::Timestamp,
  325         -
    "end_date",
         325  +
    "EndDate",
  326    326   
    9,
  327    327   
);
  328    328   
static CREATECAPACITYRESERVATIONINPUT_MEMBER_END_DATE_TYPE: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  329    329   
    ::aws_smithy_schema::ShapeId::from_static(
  330    330   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationInput$EndDateType",
  331    331   
        "com.amazonaws.ec2.synthetic",
  332    332   
        "CreateCapacityReservationInput",
  333    333   
    ),
  334    334   
    ::aws_smithy_schema::ShapeType::String,
  335         -
    "end_date_type",
         335  +
    "EndDateType",
  336    336   
    10,
  337    337   
);
  338    338   
static CREATECAPACITYRESERVATIONINPUT_MEMBER_INSTANCE_MATCH_CRITERIA: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  339    339   
    ::aws_smithy_schema::ShapeId::from_static(
  340    340   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationInput$InstanceMatchCriteria",
  341    341   
        "com.amazonaws.ec2.synthetic",
  342    342   
        "CreateCapacityReservationInput",
  343    343   
    ),
  344    344   
    ::aws_smithy_schema::ShapeType::String,
  345         -
    "instance_match_criteria",
         345  +
    "InstanceMatchCriteria",
  346    346   
    11,
  347    347   
);
  348    348   
static CREATECAPACITYRESERVATIONINPUT_MEMBER_TAG_SPECIFICATIONS: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  349    349   
    ::aws_smithy_schema::ShapeId::from_static(
  350    350   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationInput$TagSpecifications",
  351    351   
        "com.amazonaws.ec2.synthetic",
  352    352   
        "CreateCapacityReservationInput",
  353    353   
    ),
  354    354   
    ::aws_smithy_schema::ShapeType::List,
  355         -
    "tag_specifications",
         355  +
    "TagSpecifications",
  356    356   
    12,
  357    357   
);
  358    358   
static CREATECAPACITYRESERVATIONINPUT_MEMBER_DRY_RUN: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  359    359   
    ::aws_smithy_schema::ShapeId::from_static(
  360    360   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationInput$DryRun",
  361    361   
        "com.amazonaws.ec2.synthetic",
  362    362   
        "CreateCapacityReservationInput",
  363    363   
    ),
  364    364   
    ::aws_smithy_schema::ShapeType::Boolean,
  365         -
    "dry_run",
         365  +
    "DryRun",
  366    366   
    13,
  367    367   
);
  368    368   
static CREATECAPACITYRESERVATIONINPUT_MEMBER_OUTPOST_ARN: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  369    369   
    ::aws_smithy_schema::ShapeId::from_static(
  370    370   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationInput$OutpostArn",
  371    371   
        "com.amazonaws.ec2.synthetic",
  372    372   
        "CreateCapacityReservationInput",
  373    373   
    ),
  374    374   
    ::aws_smithy_schema::ShapeType::String,
  375         -
    "outpost_arn",
         375  +
    "OutpostArn",
  376    376   
    14,
  377    377   
);
  378    378   
static CREATECAPACITYRESERVATIONINPUT_MEMBER_PLACEMENT_GROUP_ARN: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  379    379   
    ::aws_smithy_schema::ShapeId::from_static(
  380    380   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationInput$PlacementGroupArn",
  381    381   
        "com.amazonaws.ec2.synthetic",
  382    382   
        "CreateCapacityReservationInput",
  383    383   
    ),
  384    384   
    ::aws_smithy_schema::ShapeType::String,
  385         -
    "placement_group_arn",
         385  +
    "PlacementGroupArn",
  386    386   
    15,
  387    387   
);
  388    388   
static CREATECAPACITYRESERVATIONINPUT_MEMBER_START_DATE: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  389    389   
    ::aws_smithy_schema::ShapeId::from_static(
  390    390   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationInput$StartDate",
  391    391   
        "com.amazonaws.ec2.synthetic",
  392    392   
        "CreateCapacityReservationInput",
  393    393   
    ),
  394    394   
    ::aws_smithy_schema::ShapeType::Timestamp,
  395         -
    "start_date",
         395  +
    "StartDate",
  396    396   
    16,
  397    397   
);
  398    398   
static CREATECAPACITYRESERVATIONINPUT_MEMBER_COMMITMENT_DURATION: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  399    399   
    ::aws_smithy_schema::ShapeId::from_static(
  400    400   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationInput$CommitmentDuration",
  401    401   
        "com.amazonaws.ec2.synthetic",
  402    402   
        "CreateCapacityReservationInput",
  403    403   
    ),
  404    404   
    ::aws_smithy_schema::ShapeType::Long,
  405         -
    "commitment_duration",
         405  +
    "CommitmentDuration",
  406    406   
    17,
  407    407   
);
  408    408   
static CREATECAPACITYRESERVATIONINPUT_MEMBER_DELIVERY_PREFERENCE: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  409    409   
    ::aws_smithy_schema::ShapeId::from_static(
  410    410   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationInput$DeliveryPreference",
  411    411   
        "com.amazonaws.ec2.synthetic",
  412    412   
        "CreateCapacityReservationInput",
  413    413   
    ),
  414    414   
    ::aws_smithy_schema::ShapeType::String,
  415         -
    "delivery_preference",
         415  +
    "DeliveryPreference",
  416    416   
    18,
  417    417   
);
  418    418   
static CREATECAPACITYRESERVATIONINPUT_SCHEMA: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_struct(
  419    419   
    CREATECAPACITYRESERVATIONINPUT_SCHEMA_ID,
  420    420   
    ::aws_smithy_schema::ShapeType::Structure,
  421    421   
    &[
  422    422   
        &CREATECAPACITYRESERVATIONINPUT_MEMBER_CLIENT_TOKEN,
  423    423   
        &CREATECAPACITYRESERVATIONINPUT_MEMBER_INSTANCE_TYPE,
  424    424   
        &CREATECAPACITYRESERVATIONINPUT_MEMBER_INSTANCE_PLATFORM,
  425    425   
        &CREATECAPACITYRESERVATIONINPUT_MEMBER_AVAILABILITY_ZONE,
@@ -493,493 +646,656 @@
  513    513   
            ser.write_long(&CREATECAPACITYRESERVATIONINPUT_MEMBER_COMMITMENT_DURATION, *val)?;
  514    514   
        }
  515    515   
        if let Some(ref val) = self.delivery_preference {
  516    516   
            ser.write_string(&CREATECAPACITYRESERVATIONINPUT_MEMBER_DELIVERY_PREFERENCE, val.as_str())?;
  517    517   
        }
  518    518   
        Ok(())
  519    519   
    }
  520    520   
}
  521    521   
impl CreateCapacityReservationInput {
  522    522   
    /// Deserializes this structure from a [`ShapeDeserializer`].
  523         -
    pub fn deserialize<D: ::aws_smithy_schema::serde::ShapeDeserializer>(
  524         -
        deserializer: &mut D,
         523  +
    pub fn deserialize(
         524  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
  525    525   
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
  526    526   
        #[allow(unused_variables, unused_mut)]
  527    527   
        let mut builder = Self::builder();
  528    528   
        #[allow(
  529    529   
            unused_variables,
  530    530   
            unreachable_code,
  531    531   
            clippy::single_match,
  532    532   
            clippy::match_single_binding,
  533    533   
            clippy::diverging_sub_expression
  534    534   
        )]
  535         -
        deserializer.read_struct(&CREATECAPACITYRESERVATIONINPUT_SCHEMA, (), |_, member, deser| {
         535  +
        deserializer.read_struct(&CREATECAPACITYRESERVATIONINPUT_SCHEMA, &mut |member, deser| {
  536    536   
            match member.member_index() {
  537    537   
                Some(0) => {
  538    538   
                    builder.client_token = Some(deser.read_string(member)?);
  539    539   
                }
  540    540   
                Some(1) => {
  541    541   
                    builder.instance_type = Some(deser.read_string(member)?);
  542    542   
                }
  543    543   
                Some(2) => {
  544    544   
                    builder.instance_platform = Some(crate::types::CapacityReservationInstancePlatform::from(
  545    545   
                        deser.read_string(member)?.as_str(),
  546    546   
                    ));
  547    547   
                }
  548    548   
                Some(3) => {
  549    549   
                    builder.availability_zone = Some(deser.read_string(member)?);
  550    550   
                }
  551    551   
                Some(4) => {
  552    552   
                    builder.availability_zone_id = Some(deser.read_string(member)?);
  553    553   
                }
  554    554   
                Some(5) => {
  555    555   
                    builder.tenancy = Some(crate::types::CapacityReservationTenancy::from(deser.read_string(member)?.as_str()));
  556    556   
                }
  557    557   
                Some(6) => {
  558    558   
                    builder.instance_count = Some(deser.read_integer(member)?);
  559    559   
                }
  560    560   
                Some(7) => {
  561    561   
                    builder.ebs_optimized = Some(deser.read_boolean(member)?);
  562    562   
                }
  563    563   
                Some(8) => {
  564    564   
                    builder.ephemeral_storage = Some(deser.read_boolean(member)?);
  565    565   
                }
  566    566   
                Some(9) => {
  567    567   
                    builder.end_date = Some(deser.read_timestamp(member)?);
  568    568   
                }
  569    569   
                Some(10) => {
  570    570   
                    builder.end_date_type = Some(crate::types::EndDateType::from(deser.read_string(member)?.as_str()));
  571    571   
                }
  572    572   
                Some(11) => {
  573    573   
                    builder.instance_match_criteria = Some(crate::types::InstanceMatchCriteria::from(deser.read_string(member)?.as_str()));
  574    574   
                }
  575    575   
                Some(12) => {
  576    576   
                    builder.tag_specifications = Some({
  577         -
                        let container = if let Some(cap) = deser.container_size() {
  578         -
                            Vec::with_capacity(cap)
  579         -
                        } else {
  580         -
                            Vec::new()
  581         -
                        };
  582         -
                        deser.read_list(member, container, |mut list, deser| {
  583         -
                            list.push(crate::types::TagSpecification::deserialize(deser)?);
  584         -
                            Ok(list)
  585         -
                        })?
         577  +
                        let mut container = Vec::new();
         578  +
                        deser.read_list(member, &mut |deser| {
         579  +
                            container.push(crate::types::TagSpecification::deserialize(deser)?);
         580  +
                            Ok(())
         581  +
                        })?;
         582  +
                        container
  586    583   
                    });
  587    584   
                }
  588    585   
                Some(13) => {
  589    586   
                    builder.dry_run = Some(deser.read_boolean(member)?);
  590    587   
                }
  591    588   
                Some(14) => {
  592    589   
                    builder.outpost_arn = Some(deser.read_string(member)?);
  593    590   
                }
  594    591   
                Some(15) => {
  595    592   
                    builder.placement_group_arn = Some(deser.read_string(member)?);
  596    593   
                }
  597    594   
                Some(16) => {
  598    595   
                    builder.start_date = Some(deser.read_timestamp(member)?);
  599    596   
                }
  600    597   
                Some(17) => {
  601    598   
                    builder.commitment_duration = Some(deser.read_long(member)?);
  602    599   
                }
  603    600   
                Some(18) => {
  604    601   
                    builder.delivery_preference = Some(crate::types::CapacityReservationDeliveryPreference::from(
  605    602   
                        deser.read_string(member)?.as_str(),
  606    603   
                    ));
  607    604   
                }
  608    605   
                _ => {}
  609    606   
            }
  610    607   
            Ok(())
  611    608   
        })?;
         609  +
        builder.instance_type = builder.instance_type.or(Some(String::new()));
         610  +
        builder.instance_count = builder.instance_count.or(Some(0i32));
  612    611   
        builder
  613    612   
            .build()
  614    613   
            .map_err(|e| aws_smithy_schema::serde::SerdeError::Custom { message: e.to_string() })
  615    614   
    }
  616    615   
}
         616  +
impl CreateCapacityReservationInput {
         617  +
    /// Deserializes this structure from a body deserializer and HTTP response.
         618  +
    pub fn deserialize_with_response(
         619  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
         620  +
        _headers: &::aws_smithy_runtime_api::http::Headers,
         621  +
        _status: u16,
         622  +
        _body: &[u8],
         623  +
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
         624  +
        Self::deserialize(deserializer)
         625  +
    }
         626  +
}
  617    627   
impl CreateCapacityReservationInput {
  618    628   
    /// Creates a new builder-style object to manufacture [`CreateCapacityReservationInput`](crate::operation::create_capacity_reservation::CreateCapacityReservationInput).
  619    629   
    pub fn builder() -> crate::operation::create_capacity_reservation::builders::CreateCapacityReservationInputBuilder {
  620    630   
        crate::operation::create_capacity_reservation::builders::CreateCapacityReservationInputBuilder::default()
  621    631   
    }
  622    632   
}
  623    633   
  624    634   
/// A builder for [`CreateCapacityReservationInput`](crate::operation::create_capacity_reservation::CreateCapacityReservationInput).
  625    635   
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
  626    636   
#[non_exhaustive]

tmp-codegen-diff/aws-sdk/sdk/ec2/src/operation/create_capacity_reservation/_create_capacity_reservation_output.rs

@@ -1,1 +97,144 @@
   18     18   
    "com.amazonaws.ec2.synthetic",
   19     19   
    "CreateCapacityReservationOutput",
   20     20   
);
   21     21   
static CREATECAPACITYRESERVATIONOUTPUT_MEMBER_CAPACITY_RESERVATION: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
   22     22   
    ::aws_smithy_schema::ShapeId::from_static(
   23     23   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationOutput$CapacityReservation",
   24     24   
        "com.amazonaws.ec2.synthetic",
   25     25   
        "CreateCapacityReservationOutput",
   26     26   
    ),
   27     27   
    ::aws_smithy_schema::ShapeType::Structure,
   28         -
    "capacity_reservation",
          28  +
    "CapacityReservation",
   29     29   
    0,
   30     30   
)
   31     31   
.with_xml_name("capacityReservation");
          32  +
static CREATECAPACITYRESERVATIONOUTPUT_MEMBER__REQUEST_ID: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
          33  +
    ::aws_smithy_schema::ShapeId::from_static("synthetic#request_id", "synthetic", "request_id"),
          34  +
    ::aws_smithy_schema::ShapeType::String,
          35  +
    "request_id",
          36  +
    1,
          37  +
)
          38  +
.with_http_header("x-amzn-requestid");
   32     39   
static CREATECAPACITYRESERVATIONOUTPUT_SCHEMA: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_struct(
   33     40   
    CREATECAPACITYRESERVATIONOUTPUT_SCHEMA_ID,
   34     41   
    ::aws_smithy_schema::ShapeType::Structure,
   35         -
    &[&CREATECAPACITYRESERVATIONOUTPUT_MEMBER_CAPACITY_RESERVATION],
          42  +
    &[
          43  +
        &CREATECAPACITYRESERVATIONOUTPUT_MEMBER_CAPACITY_RESERVATION,
          44  +
        &CREATECAPACITYRESERVATIONOUTPUT_MEMBER__REQUEST_ID,
          45  +
    ],
   36     46   
);
   37     47   
impl CreateCapacityReservationOutput {
   38     48   
    /// The schema for this shape.
   39     49   
    pub const SCHEMA: &'static ::aws_smithy_schema::Schema = &CREATECAPACITYRESERVATIONOUTPUT_SCHEMA;
   40     50   
}
   41     51   
impl ::aws_smithy_schema::serde::SerializableStruct for CreateCapacityReservationOutput {
   42     52   
    #[allow(unused_variables, clippy::diverging_sub_expression)]
   43     53   
    fn serialize_members(
   44     54   
        &self,
   45     55   
        ser: &mut dyn ::aws_smithy_schema::serde::ShapeSerializer,
   46     56   
    ) -> ::std::result::Result<(), ::aws_smithy_schema::serde::SerdeError> {
   47     57   
        if let Some(ref val) = self.capacity_reservation {
   48     58   
            ser.write_struct(&CREATECAPACITYRESERVATIONOUTPUT_MEMBER_CAPACITY_RESERVATION, val)?;
   49     59   
        }
   50     60   
        Ok(())
   51     61   
    }
   52     62   
}
   53     63   
impl CreateCapacityReservationOutput {
   54     64   
    /// Deserializes this structure from a [`ShapeDeserializer`].
   55         -
    pub fn deserialize<D: ::aws_smithy_schema::serde::ShapeDeserializer>(
   56         -
        deserializer: &mut D,
          65  +
    pub fn deserialize(
          66  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
   57     67   
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
   58     68   
        #[allow(unused_variables, unused_mut)]
   59     69   
        let mut builder = Self::builder();
   60     70   
        #[allow(
   61     71   
            unused_variables,
   62     72   
            unreachable_code,
   63     73   
            clippy::single_match,
   64     74   
            clippy::match_single_binding,
   65     75   
            clippy::diverging_sub_expression
   66     76   
        )]
   67         -
        deserializer.read_struct(&CREATECAPACITYRESERVATIONOUTPUT_SCHEMA, (), |_, member, deser| {
          77  +
        deserializer.read_struct(&CREATECAPACITYRESERVATIONOUTPUT_SCHEMA, &mut |member, deser| {
          78  +
            match member.member_index() {
          79  +
                Some(0) => {
          80  +
                    builder.capacity_reservation = Some(crate::types::CapacityReservation::deserialize(deser)?);
          81  +
                }
          82  +
                Some(1) => {
          83  +
                    builder._request_id = Some(deser.read_string(member)?);
          84  +
                }
          85  +
                _ => {}
          86  +
            }
          87  +
            Ok(())
          88  +
        })?;
          89  +
        Ok(builder.build())
          90  +
    }
          91  +
}
          92  +
impl CreateCapacityReservationOutput {
          93  +
    /// Deserializes this structure from a body deserializer and HTTP response headers.
          94  +
    /// Header-bound members are read directly from headers, avoiding runtime
          95  +
    /// member iteration overhead. Body members are read via the deserializer.
          96  +
    pub fn deserialize_with_response(
          97  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
          98  +
        headers: &::aws_smithy_runtime_api::http::Headers,
          99  +
        _status: u16,
         100  +
        _body: &[u8],
         101  +
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
         102  +
        #[allow(unused_variables, unused_mut)]
         103  +
        let mut builder = Self::builder();
         104  +
        if let Some(val) = headers.get("x-amzn-requestid") {
         105  +
            builder._request_id = Some(val.to_string());
         106  +
        }
         107  +
        #[allow(
         108  +
            unused_variables,
         109  +
            unreachable_code,
         110  +
            clippy::single_match,
         111  +
            clippy::match_single_binding,
         112  +
            clippy::diverging_sub_expression
         113  +
        )]
         114  +
        deserializer.read_struct(&CREATECAPACITYRESERVATIONOUTPUT_SCHEMA, &mut |member, deser| {
   68    115   
            match member.member_index() {
   69    116   
                Some(0) => {
   70    117   
                    builder.capacity_reservation = Some(crate::types::CapacityReservation::deserialize(deser)?);
   71    118   
                }
   72    119   
                _ => {}
   73    120   
            }
   74    121   
            Ok(())
   75    122   
        })?;
   76    123   
        Ok(builder.build())
   77    124   
    }

tmp-codegen-diff/aws-sdk/sdk/ec2/src/operation/create_capacity_reservation_by_splitting.rs

@@ -1,1 +40,46 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
    2      2   
/// Orchestration and serialization glue logic for `CreateCapacityReservationBySplitting`.
    3      3   
#[derive(::std::clone::Clone, ::std::default::Default, ::std::fmt::Debug)]
    4      4   
#[non_exhaustive]
    5      5   
pub struct CreateCapacityReservationBySplitting;
    6      6   
impl CreateCapacityReservationBySplitting {
    7      7   
    /// Creates a new `CreateCapacityReservationBySplitting`
    8      8   
    pub fn new() -> Self {
    9      9   
        Self
   10     10   
    }
          11  +
    /// The schema for this operation's input shape.
          12  +
    pub const INPUT_SCHEMA: &'static ::aws_smithy_schema::Schema =
          13  +
        crate::operation::create_capacity_reservation_by_splitting::CreateCapacityReservationBySplittingInput::SCHEMA;
          14  +
    /// The schema for this operation's output shape.
          15  +
    pub const OUTPUT_SCHEMA: &'static ::aws_smithy_schema::Schema =
          16  +
        crate::operation::create_capacity_reservation_by_splitting::CreateCapacityReservationBySplittingOutput::SCHEMA;
   11     17   
    pub(crate) async fn orchestrate(
   12     18   
        runtime_plugins: &::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins,
   13     19   
        input: crate::operation::create_capacity_reservation_by_splitting::CreateCapacityReservationBySplittingInput,
   14     20   
    ) -> ::std::result::Result<
   15     21   
        crate::operation::create_capacity_reservation_by_splitting::CreateCapacityReservationBySplittingOutput,
   16     22   
        ::aws_smithy_runtime_api::client::result::SdkError<
   17     23   
            crate::operation::create_capacity_reservation_by_splitting::CreateCapacityReservationBySplittingError,
   18     24   
            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
   19     25   
        >,
   20     26   
    > {
@@ -132,138 +194,201 @@
  152    158   
                crate::operation::create_capacity_reservation_by_splitting::CreateCapacityReservationBySplittingError,
  153    159   
            >::new());
  154    160   
  155    161   
        ::std::borrow::Cow::Owned(rcb)
  156    162   
    }
  157    163   
}
  158    164   
  159    165   
#[derive(Debug)]
  160    166   
struct CreateCapacityReservationBySplittingResponseDeserializer;
  161    167   
impl ::aws_smithy_runtime_api::client::ser_de::DeserializeResponse for CreateCapacityReservationBySplittingResponseDeserializer {
  162         -
    fn deserialize_nonstreaming(
         168  +
    fn deserialize_nonstreaming_with_config(
  163    169   
        &self,
  164    170   
        response: &::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
         171  +
        _cfg: &::aws_smithy_types::config_bag::ConfigBag,
  165    172   
    ) -> ::aws_smithy_runtime_api::client::interceptors::context::OutputOrError {
  166    173   
        let (success, status) = (response.status().is_success(), response.status().as_u16());
  167    174   
        let headers = response.headers();
  168    175   
        let body = response.body().bytes().expect("body loaded");
  169    176   
        #[allow(unused_mut)]
  170    177   
        let mut force_error = false;
  171    178   
        ::tracing::debug!(request_id = ?::aws_types::request_id::RequestId::request_id(response));
  172    179   
        let parse_result = if !success && status != 200 || force_error {
  173    180   
            crate::protocol_serde::shape_create_capacity_reservation_by_splitting::de_create_capacity_reservation_by_splitting_http_error(
  174    181   
                status, headers, body,

tmp-codegen-diff/aws-sdk/sdk/ec2/src/operation/create_capacity_reservation_by_splitting/_create_capacity_reservation_by_splitting_input.rs

@@ -23,23 +224,234 @@
   43     43   
    "com.amazonaws.ec2.synthetic",
   44     44   
    "CreateCapacityReservationBySplittingInput",
   45     45   
);
   46     46   
static CREATECAPACITYRESERVATIONBYSPLITTINGINPUT_MEMBER_DRY_RUN: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
   47     47   
    ::aws_smithy_schema::ShapeId::from_static(
   48     48   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationBySplittingInput$DryRun",
   49     49   
        "com.amazonaws.ec2.synthetic",
   50     50   
        "CreateCapacityReservationBySplittingInput",
   51     51   
    ),
   52     52   
    ::aws_smithy_schema::ShapeType::Boolean,
   53         -
    "dry_run",
          53  +
    "DryRun",
   54     54   
    0,
   55     55   
);
   56     56   
static CREATECAPACITYRESERVATIONBYSPLITTINGINPUT_MEMBER_CLIENT_TOKEN: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
   57     57   
    ::aws_smithy_schema::ShapeId::from_static(
   58     58   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationBySplittingInput$ClientToken",
   59     59   
        "com.amazonaws.ec2.synthetic",
   60     60   
        "CreateCapacityReservationBySplittingInput",
   61     61   
    ),
   62     62   
    ::aws_smithy_schema::ShapeType::String,
   63         -
    "client_token",
          63  +
    "ClientToken",
   64     64   
    1,
   65     65   
);
   66     66   
static CREATECAPACITYRESERVATIONBYSPLITTINGINPUT_MEMBER_SOURCE_CAPACITY_RESERVATION_ID: ::aws_smithy_schema::Schema =
   67     67   
    ::aws_smithy_schema::Schema::new_member(
   68     68   
        ::aws_smithy_schema::ShapeId::from_static(
   69     69   
            "com.amazonaws.ec2.synthetic#CreateCapacityReservationBySplittingInput$SourceCapacityReservationId",
   70     70   
            "com.amazonaws.ec2.synthetic",
   71     71   
            "CreateCapacityReservationBySplittingInput",
   72     72   
        ),
   73     73   
        ::aws_smithy_schema::ShapeType::String,
   74         -
        "source_capacity_reservation_id",
          74  +
        "SourceCapacityReservationId",
   75     75   
        2,
   76     76   
    );
   77     77   
static CREATECAPACITYRESERVATIONBYSPLITTINGINPUT_MEMBER_INSTANCE_COUNT: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
   78     78   
    ::aws_smithy_schema::ShapeId::from_static(
   79     79   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationBySplittingInput$InstanceCount",
   80     80   
        "com.amazonaws.ec2.synthetic",
   81     81   
        "CreateCapacityReservationBySplittingInput",
   82     82   
    ),
   83     83   
    ::aws_smithy_schema::ShapeType::Integer,
   84         -
    "instance_count",
          84  +
    "InstanceCount",
   85     85   
    3,
   86     86   
);
   87     87   
static CREATECAPACITYRESERVATIONBYSPLITTINGINPUT_MEMBER_TAG_SPECIFICATIONS: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
   88     88   
    ::aws_smithy_schema::ShapeId::from_static(
   89     89   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationBySplittingInput$TagSpecifications",
   90     90   
        "com.amazonaws.ec2.synthetic",
   91     91   
        "CreateCapacityReservationBySplittingInput",
   92     92   
    ),
   93     93   
    ::aws_smithy_schema::ShapeType::List,
   94         -
    "tag_specifications",
          94  +
    "TagSpecifications",
   95     95   
    4,
   96     96   
)
   97     97   
.with_xml_name("TagSpecification");
   98     98   
static CREATECAPACITYRESERVATIONBYSPLITTINGINPUT_SCHEMA: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_struct(
   99     99   
    CREATECAPACITYRESERVATIONBYSPLITTINGINPUT_SCHEMA_ID,
  100    100   
    ::aws_smithy_schema::ShapeType::Structure,
  101    101   
    &[
  102    102   
        &CREATECAPACITYRESERVATIONBYSPLITTINGINPUT_MEMBER_DRY_RUN,
  103    103   
        &CREATECAPACITYRESERVATIONBYSPLITTINGINPUT_MEMBER_CLIENT_TOKEN,
  104    104   
        &CREATECAPACITYRESERVATIONBYSPLITTINGINPUT_MEMBER_SOURCE_CAPACITY_RESERVATION_ID,
  105    105   
        &CREATECAPACITYRESERVATIONBYSPLITTINGINPUT_MEMBER_INSTANCE_COUNT,
  106    106   
        &CREATECAPACITYRESERVATIONBYSPLITTINGINPUT_MEMBER_TAG_SPECIFICATIONS,
  107    107   
    ],
  108    108   
);
  109    109   
impl CreateCapacityReservationBySplittingInput {
  110    110   
    /// The schema for this shape.
  111    111   
    pub const SCHEMA: &'static ::aws_smithy_schema::Schema = &CREATECAPACITYRESERVATIONBYSPLITTINGINPUT_SCHEMA;
  112    112   
}
  113    113   
impl ::aws_smithy_schema::serde::SerializableStruct for CreateCapacityReservationBySplittingInput {
  114    114   
    #[allow(unused_variables, clippy::diverging_sub_expression)]
  115    115   
    fn serialize_members(
  116    116   
        &self,
  117    117   
        ser: &mut dyn ::aws_smithy_schema::serde::ShapeSerializer,
  118    118   
    ) -> ::std::result::Result<(), ::aws_smithy_schema::serde::SerdeError> {
  119    119   
        if let Some(ref val) = self.dry_run {
  120    120   
            ser.write_boolean(&CREATECAPACITYRESERVATIONBYSPLITTINGINPUT_MEMBER_DRY_RUN, *val)?;
  121    121   
        }
  122    122   
        if let Some(ref val) = self.client_token {
  123    123   
            ser.write_string(&CREATECAPACITYRESERVATIONBYSPLITTINGINPUT_MEMBER_CLIENT_TOKEN, val)?;
  124    124   
        }
  125    125   
        if let Some(ref val) = self.source_capacity_reservation_id {
  126    126   
            ser.write_string(&CREATECAPACITYRESERVATIONBYSPLITTINGINPUT_MEMBER_SOURCE_CAPACITY_RESERVATION_ID, val)?;
  127    127   
        }
  128    128   
        if let Some(ref val) = self.instance_count {
  129    129   
            ser.write_integer(&CREATECAPACITYRESERVATIONBYSPLITTINGINPUT_MEMBER_INSTANCE_COUNT, *val)?;
  130    130   
        }
  131    131   
        if let Some(ref val) = self.tag_specifications {
  132    132   
            ser.write_list(
  133    133   
                &CREATECAPACITYRESERVATIONBYSPLITTINGINPUT_MEMBER_TAG_SPECIFICATIONS,
  134    134   
                &|ser: &mut dyn ::aws_smithy_schema::serde::ShapeSerializer| {
  135    135   
                    for item in val {
  136    136   
                        ser.write_struct(crate::types::TagSpecification::SCHEMA, item)?;
  137    137   
                    }
  138    138   
                    Ok(())
  139    139   
                },
  140    140   
            )?;
  141    141   
        }
  142    142   
        Ok(())
  143    143   
    }
  144    144   
}
  145    145   
impl CreateCapacityReservationBySplittingInput {
  146    146   
    /// Deserializes this structure from a [`ShapeDeserializer`].
  147         -
    pub fn deserialize<D: ::aws_smithy_schema::serde::ShapeDeserializer>(
  148         -
        deserializer: &mut D,
         147  +
    pub fn deserialize(
         148  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
  149    149   
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
  150    150   
        #[allow(unused_variables, unused_mut)]
  151    151   
        let mut builder = Self::builder();
  152    152   
        #[allow(
  153    153   
            unused_variables,
  154    154   
            unreachable_code,
  155    155   
            clippy::single_match,
  156    156   
            clippy::match_single_binding,
  157    157   
            clippy::diverging_sub_expression
  158    158   
        )]
  159         -
        deserializer.read_struct(&CREATECAPACITYRESERVATIONBYSPLITTINGINPUT_SCHEMA, (), |_, member, deser| {
         159  +
        deserializer.read_struct(&CREATECAPACITYRESERVATIONBYSPLITTINGINPUT_SCHEMA, &mut |member, deser| {
  160    160   
            match member.member_index() {
  161    161   
                Some(0) => {
  162    162   
                    builder.dry_run = Some(deser.read_boolean(member)?);
  163    163   
                }
  164    164   
                Some(1) => {
  165    165   
                    builder.client_token = Some(deser.read_string(member)?);
  166    166   
                }
  167    167   
                Some(2) => {
  168    168   
                    builder.source_capacity_reservation_id = Some(deser.read_string(member)?);
  169    169   
                }
  170    170   
                Some(3) => {
  171    171   
                    builder.instance_count = Some(deser.read_integer(member)?);
  172    172   
                }
  173    173   
                Some(4) => {
  174    174   
                    builder.tag_specifications = Some({
  175         -
                        let container = if let Some(cap) = deser.container_size() {
  176         -
                            Vec::with_capacity(cap)
  177         -
                        } else {
  178         -
                            Vec::new()
  179         -
                        };
  180         -
                        deser.read_list(member, container, |mut list, deser| {
  181         -
                            list.push(crate::types::TagSpecification::deserialize(deser)?);
  182         -
                            Ok(list)
  183         -
                        })?
         175  +
                        let mut container = Vec::new();
         176  +
                        deser.read_list(member, &mut |deser| {
         177  +
                            container.push(crate::types::TagSpecification::deserialize(deser)?);
         178  +
                            Ok(())
         179  +
                        })?;
         180  +
                        container
  184    181   
                    });
  185    182   
                }
  186    183   
                _ => {}
  187    184   
            }
  188    185   
            Ok(())
  189    186   
        })?;
         187  +
        builder.source_capacity_reservation_id = builder.source_capacity_reservation_id.or(Some(String::new()));
         188  +
        builder.instance_count = builder.instance_count.or(Some(0i32));
  190    189   
        builder
  191    190   
            .build()
  192    191   
            .map_err(|e| aws_smithy_schema::serde::SerdeError::Custom { message: e.to_string() })
  193    192   
    }
  194    193   
}
         194  +
impl CreateCapacityReservationBySplittingInput {
         195  +
    /// Deserializes this structure from a body deserializer and HTTP response.
         196  +
    pub fn deserialize_with_response(
         197  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
         198  +
        _headers: &::aws_smithy_runtime_api::http::Headers,
         199  +
        _status: u16,
         200  +
        _body: &[u8],
         201  +
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
         202  +
        Self::deserialize(deserializer)
         203  +
    }
         204  +
}
  195    205   
impl CreateCapacityReservationBySplittingInput {
  196    206   
    /// Creates a new builder-style object to manufacture [`CreateCapacityReservationBySplittingInput`](crate::operation::create_capacity_reservation_by_splitting::CreateCapacityReservationBySplittingInput).
  197    207   
    pub fn builder() -> crate::operation::create_capacity_reservation_by_splitting::builders::CreateCapacityReservationBySplittingInputBuilder {
  198    208   
        crate::operation::create_capacity_reservation_by_splitting::builders::CreateCapacityReservationBySplittingInputBuilder::default()
  199    209   
    }
  200    210   
}
  201    211   
  202    212   
/// A builder for [`CreateCapacityReservationBySplittingInput`](crate::operation::create_capacity_reservation_by_splitting::CreateCapacityReservationBySplittingInput).
  203    213   
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
  204    214   
#[non_exhaustive]

tmp-codegen-diff/aws-sdk/sdk/ec2/src/operation/create_capacity_reservation_by_splitting/_create_capacity_reservation_by_splitting_output.rs

@@ -11,11 +143,194 @@
   31     31   
    "CreateCapacityReservationBySplittingOutput",
   32     32   
);
   33     33   
static CREATECAPACITYRESERVATIONBYSPLITTINGOUTPUT_MEMBER_SOURCE_CAPACITY_RESERVATION: ::aws_smithy_schema::Schema =
   34     34   
    ::aws_smithy_schema::Schema::new_member(
   35     35   
        ::aws_smithy_schema::ShapeId::from_static(
   36     36   
            "com.amazonaws.ec2.synthetic#CreateCapacityReservationBySplittingOutput$SourceCapacityReservation",
   37     37   
            "com.amazonaws.ec2.synthetic",
   38     38   
            "CreateCapacityReservationBySplittingOutput",
   39     39   
        ),
   40     40   
        ::aws_smithy_schema::ShapeType::Structure,
   41         -
        "source_capacity_reservation",
          41  +
        "SourceCapacityReservation",
   42     42   
        0,
   43     43   
    )
   44     44   
    .with_xml_name("sourceCapacityReservation");
   45     45   
static CREATECAPACITYRESERVATIONBYSPLITTINGOUTPUT_MEMBER_DESTINATION_CAPACITY_RESERVATION: ::aws_smithy_schema::Schema =
   46     46   
    ::aws_smithy_schema::Schema::new_member(
   47     47   
        ::aws_smithy_schema::ShapeId::from_static(
   48     48   
            "com.amazonaws.ec2.synthetic#CreateCapacityReservationBySplittingOutput$DestinationCapacityReservation",
   49     49   
            "com.amazonaws.ec2.synthetic",
   50     50   
            "CreateCapacityReservationBySplittingOutput",
   51     51   
        ),
   52     52   
        ::aws_smithy_schema::ShapeType::Structure,
   53         -
        "destination_capacity_reservation",
          53  +
        "DestinationCapacityReservation",
   54     54   
        1,
   55     55   
    )
   56     56   
    .with_xml_name("destinationCapacityReservation");
   57     57   
static CREATECAPACITYRESERVATIONBYSPLITTINGOUTPUT_MEMBER_INSTANCE_COUNT: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
   58     58   
    ::aws_smithy_schema::ShapeId::from_static(
   59     59   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationBySplittingOutput$InstanceCount",
   60     60   
        "com.amazonaws.ec2.synthetic",
   61     61   
        "CreateCapacityReservationBySplittingOutput",
   62     62   
    ),
   63     63   
    ::aws_smithy_schema::ShapeType::Integer,
   64         -
    "instance_count",
          64  +
    "InstanceCount",
   65     65   
    2,
   66     66   
)
   67     67   
.with_xml_name("instanceCount");
          68  +
static CREATECAPACITYRESERVATIONBYSPLITTINGOUTPUT_MEMBER__REQUEST_ID: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
          69  +
    ::aws_smithy_schema::ShapeId::from_static("synthetic#request_id", "synthetic", "request_id"),
          70  +
    ::aws_smithy_schema::ShapeType::String,
          71  +
    "request_id",
          72  +
    3,
          73  +
)
          74  +
.with_http_header("x-amzn-requestid");
   68     75   
static CREATECAPACITYRESERVATIONBYSPLITTINGOUTPUT_SCHEMA: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_struct(
   69     76   
    CREATECAPACITYRESERVATIONBYSPLITTINGOUTPUT_SCHEMA_ID,
   70     77   
    ::aws_smithy_schema::ShapeType::Structure,
   71     78   
    &[
   72     79   
        &CREATECAPACITYRESERVATIONBYSPLITTINGOUTPUT_MEMBER_SOURCE_CAPACITY_RESERVATION,
   73     80   
        &CREATECAPACITYRESERVATIONBYSPLITTINGOUTPUT_MEMBER_DESTINATION_CAPACITY_RESERVATION,
   74     81   
        &CREATECAPACITYRESERVATIONBYSPLITTINGOUTPUT_MEMBER_INSTANCE_COUNT,
          82  +
        &CREATECAPACITYRESERVATIONBYSPLITTINGOUTPUT_MEMBER__REQUEST_ID,
   75     83   
    ],
   76     84   
);
   77     85   
impl CreateCapacityReservationBySplittingOutput {
   78     86   
    /// The schema for this shape.
   79     87   
    pub const SCHEMA: &'static ::aws_smithy_schema::Schema = &CREATECAPACITYRESERVATIONBYSPLITTINGOUTPUT_SCHEMA;
   80     88   
}
   81     89   
impl ::aws_smithy_schema::serde::SerializableStruct for CreateCapacityReservationBySplittingOutput {
   82     90   
    #[allow(unused_variables, clippy::diverging_sub_expression)]
   83     91   
    fn serialize_members(
   84     92   
        &self,
   85     93   
        ser: &mut dyn ::aws_smithy_schema::serde::ShapeSerializer,
   86     94   
    ) -> ::std::result::Result<(), ::aws_smithy_schema::serde::SerdeError> {
   87     95   
        if let Some(ref val) = self.source_capacity_reservation {
   88     96   
            ser.write_struct(&CREATECAPACITYRESERVATIONBYSPLITTINGOUTPUT_MEMBER_SOURCE_CAPACITY_RESERVATION, val)?;
   89     97   
        }
   90     98   
        if let Some(ref val) = self.destination_capacity_reservation {
   91     99   
            ser.write_struct(&CREATECAPACITYRESERVATIONBYSPLITTINGOUTPUT_MEMBER_DESTINATION_CAPACITY_RESERVATION, val)?;
   92    100   
        }
   93    101   
        if let Some(ref val) = self.instance_count {
   94    102   
            ser.write_integer(&CREATECAPACITYRESERVATIONBYSPLITTINGOUTPUT_MEMBER_INSTANCE_COUNT, *val)?;
   95    103   
        }
   96    104   
        Ok(())
   97    105   
    }
   98    106   
}
   99    107   
impl CreateCapacityReservationBySplittingOutput {
  100    108   
    /// Deserializes this structure from a [`ShapeDeserializer`].
  101         -
    pub fn deserialize<D: ::aws_smithy_schema::serde::ShapeDeserializer>(
  102         -
        deserializer: &mut D,
         109  +
    pub fn deserialize(
         110  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
  103    111   
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
  104    112   
        #[allow(unused_variables, unused_mut)]
  105    113   
        let mut builder = Self::builder();
  106    114   
        #[allow(
  107    115   
            unused_variables,
  108    116   
            unreachable_code,
  109    117   
            clippy::single_match,
  110    118   
            clippy::match_single_binding,
  111    119   
            clippy::diverging_sub_expression
  112    120   
        )]
  113         -
        deserializer.read_struct(&CREATECAPACITYRESERVATIONBYSPLITTINGOUTPUT_SCHEMA, (), |_, member, deser| {
         121  +
        deserializer.read_struct(&CREATECAPACITYRESERVATIONBYSPLITTINGOUTPUT_SCHEMA, &mut |member, deser| {
         122  +
            match member.member_index() {
         123  +
                Some(0) => {
         124  +
                    builder.source_capacity_reservation = Some(crate::types::CapacityReservation::deserialize(deser)?);
         125  +
                }
         126  +
                Some(1) => {
         127  +
                    builder.destination_capacity_reservation = Some(crate::types::CapacityReservation::deserialize(deser)?);
         128  +
                }
         129  +
                Some(2) => {
         130  +
                    builder.instance_count = Some(deser.read_integer(member)?);
         131  +
                }
         132  +
                Some(3) => {
         133  +
                    builder._request_id = Some(deser.read_string(member)?);
         134  +
                }
         135  +
                _ => {}
         136  +
            }
         137  +
            Ok(())
         138  +
        })?;
         139  +
        Ok(builder.build())
         140  +
    }
         141  +
}
         142  +
impl CreateCapacityReservationBySplittingOutput {
         143  +
    /// Deserializes this structure from a body deserializer and HTTP response headers.
         144  +
    /// Header-bound members are read directly from headers, avoiding runtime
         145  +
    /// member iteration overhead. Body members are read via the deserializer.
         146  +
    pub fn deserialize_with_response(
         147  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
         148  +
        headers: &::aws_smithy_runtime_api::http::Headers,
         149  +
        _status: u16,
         150  +
        _body: &[u8],
         151  +
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
         152  +
        #[allow(unused_variables, unused_mut)]
         153  +
        let mut builder = Self::builder();
         154  +
        if let Some(val) = headers.get("x-amzn-requestid") {
         155  +
            builder._request_id = Some(val.to_string());
         156  +
        }
         157  +
        #[allow(
         158  +
            unused_variables,
         159  +
            unreachable_code,
         160  +
            clippy::single_match,
         161  +
            clippy::match_single_binding,
         162  +
            clippy::diverging_sub_expression
         163  +
        )]
         164  +
        deserializer.read_struct(&CREATECAPACITYRESERVATIONBYSPLITTINGOUTPUT_SCHEMA, &mut |member, deser| {
  114    165   
            match member.member_index() {
  115    166   
                Some(0) => {
  116    167   
                    builder.source_capacity_reservation = Some(crate::types::CapacityReservation::deserialize(deser)?);
  117    168   
                }
  118    169   
                Some(1) => {
  119    170   
                    builder.destination_capacity_reservation = Some(crate::types::CapacityReservation::deserialize(deser)?);
  120    171   
                }
  121    172   
                Some(2) => {
  122    173   
                    builder.instance_count = Some(deser.read_integer(member)?);
  123    174   
                }

tmp-codegen-diff/aws-sdk/sdk/ec2/src/operation/create_capacity_reservation_fleet.rs

@@ -1,1 +40,46 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
    2      2   
/// Orchestration and serialization glue logic for `CreateCapacityReservationFleet`.
    3      3   
#[derive(::std::clone::Clone, ::std::default::Default, ::std::fmt::Debug)]
    4      4   
#[non_exhaustive]
    5      5   
pub struct CreateCapacityReservationFleet;
    6      6   
impl CreateCapacityReservationFleet {
    7      7   
    /// Creates a new `CreateCapacityReservationFleet`
    8      8   
    pub fn new() -> Self {
    9      9   
        Self
   10     10   
    }
          11  +
    /// The schema for this operation's input shape.
          12  +
    pub const INPUT_SCHEMA: &'static ::aws_smithy_schema::Schema =
          13  +
        crate::operation::create_capacity_reservation_fleet::CreateCapacityReservationFleetInput::SCHEMA;
          14  +
    /// The schema for this operation's output shape.
          15  +
    pub const OUTPUT_SCHEMA: &'static ::aws_smithy_schema::Schema =
          16  +
        crate::operation::create_capacity_reservation_fleet::CreateCapacityReservationFleetOutput::SCHEMA;
   11     17   
    pub(crate) async fn orchestrate(
   12     18   
        runtime_plugins: &::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins,
   13     19   
        input: crate::operation::create_capacity_reservation_fleet::CreateCapacityReservationFleetInput,
   14     20   
    ) -> ::std::result::Result<
   15     21   
        crate::operation::create_capacity_reservation_fleet::CreateCapacityReservationFleetOutput,
   16     22   
        ::aws_smithy_runtime_api::client::result::SdkError<
   17     23   
            crate::operation::create_capacity_reservation_fleet::CreateCapacityReservationFleetError,
   18     24   
            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
   19     25   
        >,
   20     26   
    > {
@@ -132,138 +194,201 @@
  152    158   
                crate::operation::create_capacity_reservation_fleet::CreateCapacityReservationFleetError,
  153    159   
            >::new());
  154    160   
  155    161   
        ::std::borrow::Cow::Owned(rcb)
  156    162   
    }
  157    163   
}
  158    164   
  159    165   
#[derive(Debug)]
  160    166   
struct CreateCapacityReservationFleetResponseDeserializer;
  161    167   
impl ::aws_smithy_runtime_api::client::ser_de::DeserializeResponse for CreateCapacityReservationFleetResponseDeserializer {
  162         -
    fn deserialize_nonstreaming(
         168  +
    fn deserialize_nonstreaming_with_config(
  163    169   
        &self,
  164    170   
        response: &::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
         171  +
        _cfg: &::aws_smithy_types::config_bag::ConfigBag,
  165    172   
    ) -> ::aws_smithy_runtime_api::client::interceptors::context::OutputOrError {
  166    173   
        let (success, status) = (response.status().is_success(), response.status().as_u16());
  167    174   
        let headers = response.headers();
  168    175   
        let body = response.body().bytes().expect("body loaded");
  169    176   
        #[allow(unused_mut)]
  170    177   
        let mut force_error = false;
  171    178   
        ::tracing::debug!(request_id = ?::aws_types::request_id::RequestId::request_id(response));
  172    179   
        let parse_result = if !success && status != 200 || force_error {
  173    180   
            crate::protocol_serde::shape_create_capacity_reservation_fleet::de_create_capacity_reservation_fleet_http_error(status, headers, body)
  174    181   
        } else {

tmp-codegen-diff/aws-sdk/sdk/ec2/src/operation/create_capacity_reservation_fleet/_create_capacity_reservation_fleet_input.rs

@@ -67,67 +210,210 @@
   87     87   
    "com.amazonaws.ec2.synthetic",
   88     88   
    "CreateCapacityReservationFleetInput",
   89     89   
);
   90     90   
static CREATECAPACITYRESERVATIONFLEETINPUT_MEMBER_ALLOCATION_STRATEGY: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
   91     91   
    ::aws_smithy_schema::ShapeId::from_static(
   92     92   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationFleetInput$AllocationStrategy",
   93     93   
        "com.amazonaws.ec2.synthetic",
   94     94   
        "CreateCapacityReservationFleetInput",
   95     95   
    ),
   96     96   
    ::aws_smithy_schema::ShapeType::String,
   97         -
    "allocation_strategy",
          97  +
    "AllocationStrategy",
   98     98   
    0,
   99     99   
);
  100    100   
static CREATECAPACITYRESERVATIONFLEETINPUT_MEMBER_CLIENT_TOKEN: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  101    101   
    ::aws_smithy_schema::ShapeId::from_static(
  102    102   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationFleetInput$ClientToken",
  103    103   
        "com.amazonaws.ec2.synthetic",
  104    104   
        "CreateCapacityReservationFleetInput",
  105    105   
    ),
  106    106   
    ::aws_smithy_schema::ShapeType::String,
  107         -
    "client_token",
         107  +
    "ClientToken",
  108    108   
    1,
  109    109   
);
  110    110   
static CREATECAPACITYRESERVATIONFLEETINPUT_MEMBER_INSTANCE_TYPE_SPECIFICATIONS: ::aws_smithy_schema::Schema =
  111    111   
    ::aws_smithy_schema::Schema::new_member(
  112    112   
        ::aws_smithy_schema::ShapeId::from_static(
  113    113   
            "com.amazonaws.ec2.synthetic#CreateCapacityReservationFleetInput$InstanceTypeSpecifications",
  114    114   
            "com.amazonaws.ec2.synthetic",
  115    115   
            "CreateCapacityReservationFleetInput",
  116    116   
        ),
  117    117   
        ::aws_smithy_schema::ShapeType::List,
  118         -
        "instance_type_specifications",
         118  +
        "InstanceTypeSpecifications",
  119    119   
        2,
  120    120   
    )
  121    121   
    .with_xml_name("InstanceTypeSpecification");
  122    122   
static CREATECAPACITYRESERVATIONFLEETINPUT_MEMBER_TENANCY: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  123    123   
    ::aws_smithy_schema::ShapeId::from_static(
  124    124   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationFleetInput$Tenancy",
  125    125   
        "com.amazonaws.ec2.synthetic",
  126    126   
        "CreateCapacityReservationFleetInput",
  127    127   
    ),
  128    128   
    ::aws_smithy_schema::ShapeType::String,
  129         -
    "tenancy",
         129  +
    "Tenancy",
  130    130   
    3,
  131    131   
);
  132    132   
static CREATECAPACITYRESERVATIONFLEETINPUT_MEMBER_TOTAL_TARGET_CAPACITY: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  133    133   
    ::aws_smithy_schema::ShapeId::from_static(
  134    134   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationFleetInput$TotalTargetCapacity",
  135    135   
        "com.amazonaws.ec2.synthetic",
  136    136   
        "CreateCapacityReservationFleetInput",
  137    137   
    ),
  138    138   
    ::aws_smithy_schema::ShapeType::Integer,
  139         -
    "total_target_capacity",
         139  +
    "TotalTargetCapacity",
  140    140   
    4,
  141    141   
);
  142    142   
static CREATECAPACITYRESERVATIONFLEETINPUT_MEMBER_END_DATE: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  143    143   
    ::aws_smithy_schema::ShapeId::from_static(
  144    144   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationFleetInput$EndDate",
  145    145   
        "com.amazonaws.ec2.synthetic",
  146    146   
        "CreateCapacityReservationFleetInput",
  147    147   
    ),
  148    148   
    ::aws_smithy_schema::ShapeType::Timestamp,
  149         -
    "end_date",
         149  +
    "EndDate",
  150    150   
    5,
  151    151   
);
  152    152   
static CREATECAPACITYRESERVATIONFLEETINPUT_MEMBER_INSTANCE_MATCH_CRITERIA: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  153    153   
    ::aws_smithy_schema::ShapeId::from_static(
  154    154   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationFleetInput$InstanceMatchCriteria",
  155    155   
        "com.amazonaws.ec2.synthetic",
  156    156   
        "CreateCapacityReservationFleetInput",
  157    157   
    ),
  158    158   
    ::aws_smithy_schema::ShapeType::String,
  159         -
    "instance_match_criteria",
         159  +
    "InstanceMatchCriteria",
  160    160   
    6,
  161    161   
);
  162    162   
static CREATECAPACITYRESERVATIONFLEETINPUT_MEMBER_TAG_SPECIFICATIONS: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  163    163   
    ::aws_smithy_schema::ShapeId::from_static(
  164    164   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationFleetInput$TagSpecifications",
  165    165   
        "com.amazonaws.ec2.synthetic",
  166    166   
        "CreateCapacityReservationFleetInput",
  167    167   
    ),
  168    168   
    ::aws_smithy_schema::ShapeType::List,
  169         -
    "tag_specifications",
         169  +
    "TagSpecifications",
  170    170   
    7,
  171    171   
)
  172    172   
.with_xml_name("TagSpecification");
  173    173   
static CREATECAPACITYRESERVATIONFLEETINPUT_MEMBER_DRY_RUN: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  174    174   
    ::aws_smithy_schema::ShapeId::from_static(
  175    175   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationFleetInput$DryRun",
  176    176   
        "com.amazonaws.ec2.synthetic",
  177    177   
        "CreateCapacityReservationFleetInput",
  178    178   
    ),
  179    179   
    ::aws_smithy_schema::ShapeType::Boolean,
  180         -
    "dry_run",
         180  +
    "DryRun",
  181    181   
    8,
  182    182   
);
  183    183   
static CREATECAPACITYRESERVATIONFLEETINPUT_SCHEMA: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_struct(
  184    184   
    CREATECAPACITYRESERVATIONFLEETINPUT_SCHEMA_ID,
  185    185   
    ::aws_smithy_schema::ShapeType::Structure,
  186    186   
    &[
  187    187   
        &CREATECAPACITYRESERVATIONFLEETINPUT_MEMBER_ALLOCATION_STRATEGY,
  188    188   
        &CREATECAPACITYRESERVATIONFLEETINPUT_MEMBER_CLIENT_TOKEN,
  189    189   
        &CREATECAPACITYRESERVATIONFLEETINPUT_MEMBER_INSTANCE_TYPE_SPECIFICATIONS,
  190    190   
        &CREATECAPACITYRESERVATIONFLEETINPUT_MEMBER_TENANCY,
@@ -226,226 +355,362 @@
  246    246   
            )?;
  247    247   
        }
  248    248   
        if let Some(ref val) = self.dry_run {
  249    249   
            ser.write_boolean(&CREATECAPACITYRESERVATIONFLEETINPUT_MEMBER_DRY_RUN, *val)?;
  250    250   
        }
  251    251   
        Ok(())
  252    252   
    }
  253    253   
}
  254    254   
impl CreateCapacityReservationFleetInput {
  255    255   
    /// Deserializes this structure from a [`ShapeDeserializer`].
  256         -
    pub fn deserialize<D: ::aws_smithy_schema::serde::ShapeDeserializer>(
  257         -
        deserializer: &mut D,
         256  +
    pub fn deserialize(
         257  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
  258    258   
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
  259    259   
        #[allow(unused_variables, unused_mut)]
  260    260   
        let mut builder = Self::builder();
  261    261   
        #[allow(
  262    262   
            unused_variables,
  263    263   
            unreachable_code,
  264    264   
            clippy::single_match,
  265    265   
            clippy::match_single_binding,
  266    266   
            clippy::diverging_sub_expression
  267    267   
        )]
  268         -
        deserializer.read_struct(&CREATECAPACITYRESERVATIONFLEETINPUT_SCHEMA, (), |_, member, deser| {
         268  +
        deserializer.read_struct(&CREATECAPACITYRESERVATIONFLEETINPUT_SCHEMA, &mut |member, deser| {
  269    269   
            match member.member_index() {
  270    270   
                Some(0) => {
  271    271   
                    builder.allocation_strategy = Some(deser.read_string(member)?);
  272    272   
                }
  273    273   
                Some(1) => {
  274    274   
                    builder.client_token = Some(deser.read_string(member)?);
  275    275   
                }
  276    276   
                Some(2) => {
  277    277   
                    builder.instance_type_specifications = Some({
  278         -
                        let container = if let Some(cap) = deser.container_size() {
  279         -
                            Vec::with_capacity(cap)
  280         -
                        } else {
  281         -
                            Vec::new()
  282         -
                        };
  283         -
                        deser.read_list(member, container, |mut list, deser| {
  284         -
                            list.push(crate::types::ReservationFleetInstanceSpecification::deserialize(deser)?);
  285         -
                            Ok(list)
  286         -
                        })?
         278  +
                        let mut container = Vec::new();
         279  +
                        deser.read_list(member, &mut |deser| {
         280  +
                            container.push(crate::types::ReservationFleetInstanceSpecification::deserialize(deser)?);
         281  +
                            Ok(())
         282  +
                        })?;
         283  +
                        container
  287    284   
                    });
  288    285   
                }
  289    286   
                Some(3) => {
  290    287   
                    builder.tenancy = Some(crate::types::FleetCapacityReservationTenancy::from(deser.read_string(member)?.as_str()));
  291    288   
                }
  292    289   
                Some(4) => {
  293    290   
                    builder.total_target_capacity = Some(deser.read_integer(member)?);
  294    291   
                }
  295    292   
                Some(5) => {
  296    293   
                    builder.end_date = Some(deser.read_timestamp(member)?);
  297    294   
                }
  298    295   
                Some(6) => {
  299    296   
                    builder.instance_match_criteria = Some(crate::types::FleetInstanceMatchCriteria::from(deser.read_string(member)?.as_str()));
  300    297   
                }
  301    298   
                Some(7) => {
  302    299   
                    builder.tag_specifications = Some({
  303         -
                        let container = if let Some(cap) = deser.container_size() {
  304         -
                            Vec::with_capacity(cap)
  305         -
                        } else {
  306         -
                            Vec::new()
  307         -
                        };
  308         -
                        deser.read_list(member, container, |mut list, deser| {
  309         -
                            list.push(crate::types::TagSpecification::deserialize(deser)?);
  310         -
                            Ok(list)
  311         -
                        })?
         300  +
                        let mut container = Vec::new();
         301  +
                        deser.read_list(member, &mut |deser| {
         302  +
                            container.push(crate::types::TagSpecification::deserialize(deser)?);
         303  +
                            Ok(())
         304  +
                        })?;
         305  +
                        container
  312    306   
                    });
  313    307   
                }
  314    308   
                Some(8) => {
  315    309   
                    builder.dry_run = Some(deser.read_boolean(member)?);
  316    310   
                }
  317    311   
                _ => {}
  318    312   
            }
  319    313   
            Ok(())
  320    314   
        })?;
         315  +
        builder.instance_type_specifications = builder.instance_type_specifications.or(Some(Vec::new()));
         316  +
        builder.total_target_capacity = builder.total_target_capacity.or(Some(0i32));
  321    317   
        builder
  322    318   
            .build()
  323    319   
            .map_err(|e| aws_smithy_schema::serde::SerdeError::Custom { message: e.to_string() })
  324    320   
    }
  325    321   
}
         322  +
impl CreateCapacityReservationFleetInput {
         323  +
    /// Deserializes this structure from a body deserializer and HTTP response.
         324  +
    pub fn deserialize_with_response(
         325  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
         326  +
        _headers: &::aws_smithy_runtime_api::http::Headers,
         327  +
        _status: u16,
         328  +
        _body: &[u8],
         329  +
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
         330  +
        Self::deserialize(deserializer)
         331  +
    }
         332  +
}
  326    333   
impl CreateCapacityReservationFleetInput {
  327    334   
    /// Creates a new builder-style object to manufacture [`CreateCapacityReservationFleetInput`](crate::operation::create_capacity_reservation_fleet::CreateCapacityReservationFleetInput).
  328    335   
    pub fn builder() -> crate::operation::create_capacity_reservation_fleet::builders::CreateCapacityReservationFleetInputBuilder {
  329    336   
        crate::operation::create_capacity_reservation_fleet::builders::CreateCapacityReservationFleetInputBuilder::default()
  330    337   
    }
  331    338   
}
  332    339   
  333    340   
/// A builder for [`CreateCapacityReservationFleetInput`](crate::operation::create_capacity_reservation_fleet::CreateCapacityReservationFleetInput).
  334    341   
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
  335    342   
#[non_exhaustive]

tmp-codegen-diff/aws-sdk/sdk/ec2/src/operation/create_capacity_reservation_fleet/_create_capacity_reservation_fleet_output.rs

@@ -63,63 +252,260 @@
   83     83   
    "CreateCapacityReservationFleetOutput",
   84     84   
);
   85     85   
static CREATECAPACITYRESERVATIONFLEETOUTPUT_MEMBER_CAPACITY_RESERVATION_FLEET_ID: ::aws_smithy_schema::Schema =
   86     86   
    ::aws_smithy_schema::Schema::new_member(
   87     87   
        ::aws_smithy_schema::ShapeId::from_static(
   88     88   
            "com.amazonaws.ec2.synthetic#CreateCapacityReservationFleetOutput$CapacityReservationFleetId",
   89     89   
            "com.amazonaws.ec2.synthetic",
   90     90   
            "CreateCapacityReservationFleetOutput",
   91     91   
        ),
   92     92   
        ::aws_smithy_schema::ShapeType::String,
   93         -
        "capacity_reservation_fleet_id",
          93  +
        "CapacityReservationFleetId",
   94     94   
        0,
   95     95   
    )
   96     96   
    .with_xml_name("capacityReservationFleetId");
   97     97   
static CREATECAPACITYRESERVATIONFLEETOUTPUT_MEMBER_STATE: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
   98     98   
    ::aws_smithy_schema::ShapeId::from_static(
   99     99   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationFleetOutput$State",
  100    100   
        "com.amazonaws.ec2.synthetic",
  101    101   
        "CreateCapacityReservationFleetOutput",
  102    102   
    ),
  103    103   
    ::aws_smithy_schema::ShapeType::String,
  104         -
    "state",
         104  +
    "State",
  105    105   
    1,
  106    106   
)
  107    107   
.with_xml_name("state");
  108    108   
static CREATECAPACITYRESERVATIONFLEETOUTPUT_MEMBER_TOTAL_TARGET_CAPACITY: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  109    109   
    ::aws_smithy_schema::ShapeId::from_static(
  110    110   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationFleetOutput$TotalTargetCapacity",
  111    111   
        "com.amazonaws.ec2.synthetic",
  112    112   
        "CreateCapacityReservationFleetOutput",
  113    113   
    ),
  114    114   
    ::aws_smithy_schema::ShapeType::Integer,
  115         -
    "total_target_capacity",
         115  +
    "TotalTargetCapacity",
  116    116   
    2,
  117    117   
)
  118    118   
.with_xml_name("totalTargetCapacity");
  119    119   
static CREATECAPACITYRESERVATIONFLEETOUTPUT_MEMBER_TOTAL_FULFILLED_CAPACITY: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  120    120   
    ::aws_smithy_schema::ShapeId::from_static(
  121    121   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationFleetOutput$TotalFulfilledCapacity",
  122    122   
        "com.amazonaws.ec2.synthetic",
  123    123   
        "CreateCapacityReservationFleetOutput",
  124    124   
    ),
  125    125   
    ::aws_smithy_schema::ShapeType::Double,
  126         -
    "total_fulfilled_capacity",
         126  +
    "TotalFulfilledCapacity",
  127    127   
    3,
  128    128   
)
  129    129   
.with_xml_name("totalFulfilledCapacity");
  130    130   
static CREATECAPACITYRESERVATIONFLEETOUTPUT_MEMBER_INSTANCE_MATCH_CRITERIA: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  131    131   
    ::aws_smithy_schema::ShapeId::from_static(
  132    132   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationFleetOutput$InstanceMatchCriteria",
  133    133   
        "com.amazonaws.ec2.synthetic",
  134    134   
        "CreateCapacityReservationFleetOutput",
  135    135   
    ),
  136    136   
    ::aws_smithy_schema::ShapeType::String,
  137         -
    "instance_match_criteria",
         137  +
    "InstanceMatchCriteria",
  138    138   
    4,
  139    139   
)
  140    140   
.with_xml_name("instanceMatchCriteria");
  141    141   
static CREATECAPACITYRESERVATIONFLEETOUTPUT_MEMBER_ALLOCATION_STRATEGY: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  142    142   
    ::aws_smithy_schema::ShapeId::from_static(
  143    143   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationFleetOutput$AllocationStrategy",
  144    144   
        "com.amazonaws.ec2.synthetic",
  145    145   
        "CreateCapacityReservationFleetOutput",
  146    146   
    ),
  147    147   
    ::aws_smithy_schema::ShapeType::String,
  148         -
    "allocation_strategy",
         148  +
    "AllocationStrategy",
  149    149   
    5,
  150    150   
)
  151    151   
.with_xml_name("allocationStrategy");
  152    152   
static CREATECAPACITYRESERVATIONFLEETOUTPUT_MEMBER_CREATE_TIME: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  153    153   
    ::aws_smithy_schema::ShapeId::from_static(
  154    154   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationFleetOutput$CreateTime",
  155    155   
        "com.amazonaws.ec2.synthetic",
  156    156   
        "CreateCapacityReservationFleetOutput",
  157    157   
    ),
  158    158   
    ::aws_smithy_schema::ShapeType::Timestamp,
  159         -
    "create_time",
         159  +
    "CreateTime",
  160    160   
    6,
  161    161   
)
  162    162   
.with_xml_name("createTime");
  163    163   
static CREATECAPACITYRESERVATIONFLEETOUTPUT_MEMBER_END_DATE: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  164    164   
    ::aws_smithy_schema::ShapeId::from_static(
  165    165   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationFleetOutput$EndDate",
  166    166   
        "com.amazonaws.ec2.synthetic",
  167    167   
        "CreateCapacityReservationFleetOutput",
  168    168   
    ),
  169    169   
    ::aws_smithy_schema::ShapeType::Timestamp,
  170         -
    "end_date",
         170  +
    "EndDate",
  171    171   
    7,
  172    172   
)
  173    173   
.with_xml_name("endDate");
  174    174   
static CREATECAPACITYRESERVATIONFLEETOUTPUT_MEMBER_TENANCY: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  175    175   
    ::aws_smithy_schema::ShapeId::from_static(
  176    176   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationFleetOutput$Tenancy",
  177    177   
        "com.amazonaws.ec2.synthetic",
  178    178   
        "CreateCapacityReservationFleetOutput",
  179    179   
    ),
  180    180   
    ::aws_smithy_schema::ShapeType::String,
  181         -
    "tenancy",
         181  +
    "Tenancy",
  182    182   
    8,
  183    183   
)
  184    184   
.with_xml_name("tenancy");
  185    185   
static CREATECAPACITYRESERVATIONFLEETOUTPUT_MEMBER_FLEET_CAPACITY_RESERVATIONS: ::aws_smithy_schema::Schema =
  186    186   
    ::aws_smithy_schema::Schema::new_member(
  187    187   
        ::aws_smithy_schema::ShapeId::from_static(
  188    188   
            "com.amazonaws.ec2.synthetic#CreateCapacityReservationFleetOutput$FleetCapacityReservations",
  189    189   
            "com.amazonaws.ec2.synthetic",
  190    190   
            "CreateCapacityReservationFleetOutput",
  191    191   
        ),
  192    192   
        ::aws_smithy_schema::ShapeType::List,
  193         -
        "fleet_capacity_reservations",
         193  +
        "FleetCapacityReservations",
  194    194   
        9,
  195    195   
    )
  196    196   
    .with_xml_name("fleetCapacityReservationSet");
  197    197   
static CREATECAPACITYRESERVATIONFLEETOUTPUT_MEMBER_TAGS: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
  198    198   
    ::aws_smithy_schema::ShapeId::from_static(
  199    199   
        "com.amazonaws.ec2.synthetic#CreateCapacityReservationFleetOutput$Tags",
  200    200   
        "com.amazonaws.ec2.synthetic",
  201    201   
        "CreateCapacityReservationFleetOutput",
  202    202   
    ),
  203    203   
    ::aws_smithy_schema::ShapeType::List,
  204         -
    "tags",
         204  +
    "Tags",
  205    205   
    10,
  206    206   
)
  207    207   
.with_xml_name("tagSet");
         208  +
static CREATECAPACITYRESERVATIONFLEETOUTPUT_MEMBER__REQUEST_ID: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_member(
         209  +
    ::aws_smithy_schema::ShapeId::from_static("synthetic#request_id", "synthetic", "request_id"),
         210  +
    ::aws_smithy_schema::ShapeType::String,
         211  +
    "request_id",
         212  +
    11,
         213  +
)
         214  +
.with_http_header("x-amzn-requestid");
  208    215   
static CREATECAPACITYRESERVATIONFLEETOUTPUT_SCHEMA: ::aws_smithy_schema::Schema = ::aws_smithy_schema::Schema::new_struct(
  209    216   
    CREATECAPACITYRESERVATIONFLEETOUTPUT_SCHEMA_ID,
  210    217   
    ::aws_smithy_schema::ShapeType::Structure,
  211    218   
    &[
  212    219   
        &CREATECAPACITYRESERVATIONFLEETOUTPUT_MEMBER_CAPACITY_RESERVATION_FLEET_ID,
  213    220   
        &CREATECAPACITYRESERVATIONFLEETOUTPUT_MEMBER_STATE,
  214    221   
        &CREATECAPACITYRESERVATIONFLEETOUTPUT_MEMBER_TOTAL_TARGET_CAPACITY,
  215    222   
        &CREATECAPACITYRESERVATIONFLEETOUTPUT_MEMBER_TOTAL_FULFILLED_CAPACITY,
  216    223   
        &CREATECAPACITYRESERVATIONFLEETOUTPUT_MEMBER_INSTANCE_MATCH_CRITERIA,
  217    224   
        &CREATECAPACITYRESERVATIONFLEETOUTPUT_MEMBER_ALLOCATION_STRATEGY,
  218    225   
        &CREATECAPACITYRESERVATIONFLEETOUTPUT_MEMBER_CREATE_TIME,
  219    226   
        &CREATECAPACITYRESERVATIONFLEETOUTPUT_MEMBER_END_DATE,
  220    227   
        &CREATECAPACITYRESERVATIONFLEETOUTPUT_MEMBER_TENANCY,
  221    228   
        &CREATECAPACITYRESERVATIONFLEETOUTPUT_MEMBER_FLEET_CAPACITY_RESERVATIONS,
  222    229   
        &CREATECAPACITYRESERVATIONFLEETOUTPUT_MEMBER_TAGS,
         230  +
        &CREATECAPACITYRESERVATIONFLEETOUTPUT_MEMBER__REQUEST_ID,
  223    231   
    ],
  224    232   
);
  225    233   
impl CreateCapacityReservationFleetOutput {
  226    234   
    /// The schema for this shape.
  227    235   
    pub const SCHEMA: &'static ::aws_smithy_schema::Schema = &CREATECAPACITYRESERVATIONFLEETOUTPUT_SCHEMA;
  228    236   
}
  229    237   
impl ::aws_smithy_schema::serde::SerializableStruct for CreateCapacityReservationFleetOutput {
  230    238   
    #[allow(unused_variables, clippy::diverging_sub_expression)]
  231    239   
    fn serialize_members(
  232    240   
        &self,
@@ -259,267 +383,466 @@
  279    287   
                    }
  280    288   
                    Ok(())
  281    289   
                },
  282    290   
            )?;
  283    291   
        }
  284    292   
        Ok(())
  285    293   
    }
  286    294   
}
  287    295   
impl CreateCapacityReservationFleetOutput {
  288    296   
    /// Deserializes this structure from a [`ShapeDeserializer`].
  289         -
    pub fn deserialize<D: ::aws_smithy_schema::serde::ShapeDeserializer>(
  290         -
        deserializer: &mut D,
         297  +
    pub fn deserialize(
         298  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
         299  +
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
         300  +
        #[allow(unused_variables, unused_mut)]
         301  +
        let mut builder = Self::builder();
         302  +
        #[allow(
         303  +
            unused_variables,
         304  +
            unreachable_code,
         305  +
            clippy::single_match,
         306  +
            clippy::match_single_binding,
         307  +
            clippy::diverging_sub_expression
         308  +
        )]
         309  +
        deserializer.read_struct(&CREATECAPACITYRESERVATIONFLEETOUTPUT_SCHEMA, &mut |member, deser| {
         310  +
            match member.member_index() {
         311  +
                Some(0) => {
         312  +
                    builder.capacity_reservation_fleet_id = Some(deser.read_string(member)?);
         313  +
                }
         314  +
                Some(1) => {
         315  +
                    builder.state = Some(crate::types::CapacityReservationFleetState::from(deser.read_string(member)?.as_str()));
         316  +
                }
         317  +
                Some(2) => {
         318  +
                    builder.total_target_capacity = Some(deser.read_integer(member)?);
         319  +
                }
         320  +
                Some(3) => {
         321  +
                    builder.total_fulfilled_capacity = Some(deser.read_double(member)?);
         322  +
                }
         323  +
                Some(4) => {
         324  +
                    builder.instance_match_criteria = Some(crate::types::FleetInstanceMatchCriteria::from(deser.read_string(member)?.as_str()));
         325  +
                }
         326  +
                Some(5) => {
         327  +
                    builder.allocation_strategy = Some(deser.read_string(member)?);
         328  +
                }
         329  +
                Some(6) => {
         330  +
                    builder.create_time = Some(deser.read_timestamp(member)?);
         331  +
                }
         332  +
                Some(7) => {
         333  +
                    builder.end_date = Some(deser.read_timestamp(member)?);
         334  +
                }
         335  +
                Some(8) => {
         336  +
                    builder.tenancy = Some(crate::types::FleetCapacityReservationTenancy::from(deser.read_string(member)?.as_str()));
         337  +
                }
         338  +
                Some(9) => {
         339  +
                    builder.fleet_capacity_reservations = Some({
         340  +
                        let mut container = Vec::new();
         341  +
                        deser.read_list(member, &mut |deser| {
         342  +
                            container.push(crate::types::FleetCapacityReservation::deserialize(deser)?);
         343  +
                            Ok(())
         344  +
                        })?;
         345  +
                        container
         346  +
                    });
         347  +
                }
         348  +
                Some(10) => {
         349  +
                    builder.tags = Some({
         350  +
                        let mut container = Vec::new();
         351  +
                        deser.read_list(member, &mut |deser| {
         352  +
                            container.push(crate::types::Tag::deserialize(deser)?);
         353  +
                            Ok(())
         354  +
                        })?;
         355  +
                        container
         356  +
                    });
         357  +
                }
         358  +
                Some(11) => {
         359  +
                    builder._request_id = Some(deser.read_string(member)?);
         360  +
                }
         361  +
                _ => {}
         362  +
            }
         363  +
            Ok(())
         364  +
        })?;
         365  +
        Ok(builder.build())
         366  +
    }
         367  +
}
         368  +
impl CreateCapacityReservationFleetOutput {
         369  +
    /// Deserializes this structure from a body deserializer and HTTP response headers.
         370  +
    /// Header-bound members are read directly from headers, avoiding runtime
         371  +
    /// member iteration overhead. Body members are read via the deserializer.
         372  +
    pub fn deserialize_with_response(
         373  +
        deserializer: &mut dyn ::aws_smithy_schema::serde::ShapeDeserializer,
         374  +
        headers: &::aws_smithy_runtime_api::http::Headers,
         375  +
        _status: u16,
         376  +
        _body: &[u8],
  291    377   
    ) -> ::std::result::Result<Self, ::aws_smithy_schema::serde::SerdeError> {
  292    378   
        #[allow(unused_variables, unused_mut)]
  293    379   
        let mut builder = Self::builder();
         380  +
        if let Some(val) = headers.get("x-amzn-requestid") {
         381  +
            builder._request_id = Some(val.to_string());
         382  +
        }
  294    383   
        #[allow(
  295    384   
            unused_variables,
  296    385   
            unreachable_code,
  297    386   
            clippy::single_match,
  298    387   
            clippy::match_single_binding,
  299    388   
            clippy::diverging_sub_expression
  300    389   
        )]
  301         -
        deserializer.read_struct(&CREATECAPACITYRESERVATIONFLEETOUTPUT_SCHEMA, (), |_, member, deser| {
         390  +
        deserializer.read_struct(&CREATECAPACITYRESERVATIONFLEETOUTPUT_SCHEMA, &mut |member, deser| {
  302    391   
            match member.member_index() {
  303    392   
                Some(0) => {
  304    393   
                    builder.capacity_reservation_fleet_id = Some(deser.read_string(member)?);
  305    394   
                }
  306    395   
                Some(1) => {
  307    396   
                    builder.state = Some(crate::types::CapacityReservationFleetState::from(deser.read_string(member)?.as_str()));
  308    397   
                }
  309    398   
                Some(2) => {
  310    399   
                    builder.total_target_capacity = Some(deser.read_integer(member)?);
  311    400   
                }
  312    401   
                Some(3) => {
  313    402   
                    builder.total_fulfilled_capacity = Some(deser.read_double(member)?);
  314    403   
                }
  315    404   
                Some(4) => {
  316    405   
                    builder.instance_match_criteria = Some(crate::types::FleetInstanceMatchCriteria::from(deser.read_string(member)?.as_str()));
  317    406   
                }
  318    407   
                Some(5) => {
  319    408   
                    builder.allocation_strategy = Some(deser.read_string(member)?);
  320    409   
                }
  321    410   
                Some(6) => {
  322    411   
                    builder.create_time = Some(deser.read_timestamp(member)?);
  323    412   
                }
  324    413   
                Some(7) => {
  325    414   
                    builder.end_date = Some(deser.read_timestamp(member)?);
  326    415   
                }
  327    416   
                Some(8) => {
  328    417   
                    builder.tenancy = Some(crate::types::FleetCapacityReservationTenancy::from(deser.read_string(member)?.as_str()));
  329    418   
                }
  330    419   
                Some(9) => {
  331    420   
                    builder.fleet_capacity_reservations = Some({
  332         -
                        let container = if let Some(cap) = deser.container_size() {
  333         -
                            Vec::with_capacity(cap)
  334         -
                        } else {
  335         -
                            Vec::new()
  336         -
                        };
  337         -
                        deser.read_list(member, container, |mut list, deser| {
  338         -
                            list.push(crate::types::FleetCapacityReservation::deserialize(deser)?);
  339         -
                            Ok(list)
  340         -
                        })?
         421  +
                        let mut container = Vec::new();
         422  +
                        deser.read_list(member, &mut |deser| {
         423  +
                            container.push(crate::types::FleetCapacityReservation::deserialize(deser)?);
         424  +
                            Ok(())
         425  +
                        })?;
         426  +
                        container
  341    427   
                    });
  342    428   
                }
  343    429   
                Some(10) => {
  344    430   
                    builder.tags = Some({
  345         -
                        let container = if let Some(cap) = deser.container_size() {
  346         -
                            Vec::with_capacity(cap)
  347         -
                        } else {
  348         -
                            Vec::new()
  349         -
                        };
  350         -
                        deser.read_list(member, container, |mut list, deser| {
  351         -
                            list.push(crate::types::Tag::deserialize(deser)?);
  352         -
                            Ok(list)
  353         -
                        })?
         431  +
                        let mut container = Vec::new();
         432  +
                        deser.read_list(member, &mut |deser| {
         433  +
                            container.push(crate::types::Tag::deserialize(deser)?);
         434  +
                            Ok(())
         435  +
                        })?;
         436  +
                        container
  354    437   
                    });
  355    438   
                }
  356    439   
                _ => {}
  357    440   
            }
  358    441   
            Ok(())
  359    442   
        })?;
  360    443   
        Ok(builder.build())
  361    444   
    }
  362    445   
}
  363    446   
impl ::aws_types::request_id::RequestId for CreateCapacityReservationFleetOutput {

tmp-codegen-diff/aws-sdk/sdk/ec2/src/operation/create_carrier_gateway.rs

@@ -1,1 +40,44 @@
    1      1   
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
    2      2   
/// Orchestration and serialization glue logic for `CreateCarrierGateway`.
    3      3   
#[derive(::std::clone::Clone, ::std::default::Default, ::std::fmt::Debug)]
    4      4   
#[non_exhaustive]
    5      5   
pub struct CreateCarrierGateway;
    6      6   
impl CreateCarrierGateway {
    7      7   
    /// Creates a new `CreateCarrierGateway`
    8      8   
    pub fn new() -> Self {
    9      9   
        Self
   10     10   
    }
          11  +
    /// The schema for this operation's input shape.
          12  +
    pub const INPUT_SCHEMA: &'static ::aws_smithy_schema::Schema = crate::operation::create_carrier_gateway::CreateCarrierGatewayInput::SCHEMA;
          13  +
    /// The schema for this operation's output shape.
          14  +
    pub const OUTPUT_SCHEMA: &'static ::aws_smithy_schema::Schema = crate::operation::create_carrier_gateway::CreateCarrierGatewayOutput::SCHEMA;
   11     15   
    pub(crate) async fn orchestrate(
   12     16   
        runtime_plugins: &::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins,
   13     17   
        input: crate::operation::create_carrier_gateway::CreateCarrierGatewayInput,
   14     18   
    ) -> ::std::result::Result<
   15     19   
        crate::operation::create_carrier_gateway::CreateCarrierGatewayOutput,
   16     20   
        ::aws_smithy_runtime_api::client::result::SdkError<
   17     21   
            crate::operation::create_carrier_gateway::CreateCarrierGatewayError,
   18     22   
            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
   19     23   
        >,
   20     24   
    > {
@@ -125,129 +187,192 @@
  145    149   
                crate::operation::create_carrier_gateway::CreateCarrierGatewayError,
  146    150   
            >::new());
  147    151   
  148    152   
        ::std::borrow::Cow::Owned(rcb)
  149    153   
    }
  150    154   
}
  151    155   
  152    156   
#[derive(Debug)]
  153    157   
struct CreateCarrierGatewayResponseDeserializer;
  154    158   
impl ::aws_smithy_runtime_api::client::ser_de::DeserializeResponse for CreateCarrierGatewayResponseDeserializer {
  155         -
    fn deserialize_nonstreaming(
         159  +
    fn deserialize_nonstreaming_with_config(
  156    160   
        &self,
  157    161   
        response: &::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
         162  +
        _cfg: &::aws_smithy_types::config_bag::ConfigBag,
  158    163   
    ) -> ::aws_smithy_runtime_api::client::interceptors::context::OutputOrError {
  159    164   
        let (success, status) = (response.status().is_success(), response.status().as_u16());
  160    165   
        let headers = response.headers();
  161    166   
        let body = response.body().bytes().expect("body loaded");
  162    167   
        #[allow(unused_mut)]
  163    168   
        let mut force_error = false;
  164    169   
        ::tracing::debug!(request_id = ?::aws_types::request_id::RequestId::request_id(response));
  165    170   
        let parse_result = if !success && status != 200 || force_error {
  166    171   
            crate::protocol_serde::shape_create_carrier_gateway::de_create_carrier_gateway_http_error(status, headers, body)
  167    172   
        } else {