pub fn ser_modify_transit_gateway_vpc_attachment_input_input_input(
input: &crate::operation::modify_transit_gateway_vpc_attachment::ModifyTransitGatewayVpcAttachmentInput,
) -> ::std::result::Result<::aws_smithy_types::body::SdkBody, ::aws_smithy_types::error::operation::SerializationError> {
let mut out = String::new();
#[allow(unused_mut)]
let mut writer = ::aws_smithy_query::QueryWriter::new(&mut out, "ModifyTransitGatewayVpcAttachment", "2016-11-15");
#[allow(unused_mut)]
let mut scope_1 = writer.prefix("TransitGatewayAttachmentId");
if let Some(var_2) = &input.transit_gateway_attachment_id {
scope_1.string(var_2);
}
#[allow(unused_mut)]
let mut scope_3 = writer.prefix("AddSubnetIds");
if let Some(var_4) = &input.add_subnet_ids {
if !var_4.is_empty() {
let mut list_6 = scope_3.start_list(true, Some("item"));
for item_5 in var_4 {
#[allow(unused_mut)]
let mut entry_7 = list_6.entry();
entry_7.string(item_5);
}
list_6.finish();
}
}
#[allow(unused_mut)]
let mut scope_8 = writer.prefix("RemoveSubnetIds");
if let Some(var_9) = &input.remove_subnet_ids {
if !var_9.is_empty() {
let mut list_11 = scope_8.start_list(true, Some("item"));
for item_10 in var_9 {
#[allow(unused_mut)]
let mut entry_12 = list_11.entry();
entry_12.string(item_10);
}
list_11.finish();
}
}
#[allow(unused_mut)]
let mut scope_13 = writer.prefix("Options");
if let Some(var_14) = &input.options {
crate::protocol_serde::shape_modify_transit_gateway_vpc_attachment_request_options::ser_modify_transit_gateway_vpc_attachment_request_options(scope_13, var_14)?;
}
#[allow(unused_mut)]
let mut scope_15 = writer.prefix("DryRun");
if let Some(var_16) = &input.dry_run {
scope_15.boolean(*var_16);
}
writer.finish();
Ok(::aws_smithy_types::body::SdkBody::from(out))
}