Enum aws_sdk_ec2::model::VpcEndpointType
source · #[non_exhaustive]
pub enum VpcEndpointType {
Gateway,
GatewayLoadBalancer,
Interface,
Unknown(UnknownVariantValue),
}
Expand description
When writing a match expression against VpcEndpointType
, it is important to ensure
your code is forward-compatible. That is, if a match arm handles a case for a
feature that is supported by the service but has not been represented as an enum
variant in a current version of SDK, your code should continue to work when you
upgrade SDK to a future version in which the enum does include a variant for that
feature.
Here is an example of how you can make a match expression forward-compatible:
# let vpcendpointtype = unimplemented!();
match vpcendpointtype {
VpcEndpointType::Gateway => { /* ... */ },
VpcEndpointType::GatewayLoadBalancer => { /* ... */ },
VpcEndpointType::Interface => { /* ... */ },
other @ _ if other.as_str() == "NewFeature" => { /* handles a case for `NewFeature` */ },
_ => { /* ... */ },
}
The above code demonstrates that when vpcendpointtype
represents
NewFeature
, the execution path will lead to the second last match arm,
even though the enum does not contain a variant VpcEndpointType::NewFeature
in the current version of SDK. The reason is that the variable other
,
created by the @
operator, is bound to
VpcEndpointType::Unknown(UnknownVariantValue("NewFeature".to_owned()))
and calling as_str
on it yields "NewFeature"
.
This match expression is forward-compatible when executed with a newer
version of SDK where the variant VpcEndpointType::NewFeature
is defined.
Specifically, when vpcendpointtype
represents NewFeature
,
the execution path will hit the second last match arm as before by virtue of
calling as_str
on VpcEndpointType::NewFeature
also yielding "NewFeature"
.
Explicitly matching on the Unknown
variant should
be avoided for two reasons:
- The inner data
UnknownVariantValue
is opaque, and no further information can be extracted. - It might inadvertently shadow other intended match arms.
Variants (Non-exhaustive)§
This enum is marked as non-exhaustive
Gateway
GatewayLoadBalancer
Interface
Unknown(UnknownVariantValue)
Unknown
contains new variants that have been added since this code was generated.
Implementations§
source§impl VpcEndpointType
impl VpcEndpointType
sourcepub fn as_str(&self) -> &str
pub fn as_str(&self) -> &str
Returns the &str
value of the enum member.
Examples found in repository?
More examples
5507 5508 5509 5510 5511 5512 5513 5514 5515 5516 5517 5518 5519 5520 5521 5522 5523 5524 5525 5526 5527 5528 5529 5530 5531 5532 5533 5534 5535 5536 5537 5538 5539 5540 5541 5542 5543 5544 5545 5546 5547 5548 5549 5550 5551 5552 5553 5554 5555 5556 5557 5558 5559 5560 5561 5562 5563 5564 5565 5566 5567 5568 5569 5570 5571 5572 5573 5574 5575 5576 5577 5578 5579 5580 5581 5582 5583 5584 5585 5586 5587 5588 5589 5590 5591 5592 5593 5594 5595 5596 5597 5598 5599 5600 5601 5602 5603 5604 5605 5606 5607 5608 5609
pub fn serialize_operation_crate_operation_create_vpc_endpoint(
input: &crate::input::CreateVpcEndpointInput,
) -> Result<aws_smithy_http::body::SdkBody, aws_smithy_http::operation::error::SerializationError> {
let mut out = String::new();
#[allow(unused_mut)]
let mut writer =
aws_smithy_query::QueryWriter::new(&mut out, "CreateVpcEndpoint", "2016-11-15");
#[allow(unused_mut)]
let mut scope_1607 = writer.prefix("DryRun");
if let Some(var_1608) = &input.dry_run {
scope_1607.boolean(*var_1608);
}
#[allow(unused_mut)]
let mut scope_1609 = writer.prefix("VpcEndpointType");
if let Some(var_1610) = &input.vpc_endpoint_type {
scope_1609.string(var_1610.as_str());
}
#[allow(unused_mut)]
let mut scope_1611 = writer.prefix("VpcId");
if let Some(var_1612) = &input.vpc_id {
scope_1611.string(var_1612);
}
#[allow(unused_mut)]
let mut scope_1613 = writer.prefix("ServiceName");
if let Some(var_1614) = &input.service_name {
scope_1613.string(var_1614);
}
#[allow(unused_mut)]
let mut scope_1615 = writer.prefix("PolicyDocument");
if let Some(var_1616) = &input.policy_document {
scope_1615.string(var_1616);
}
#[allow(unused_mut)]
let mut scope_1617 = writer.prefix("RouteTableId");
if let Some(var_1618) = &input.route_table_ids {
let mut list_1620 = scope_1617.start_list(true, Some("item"));
for item_1619 in var_1618 {
#[allow(unused_mut)]
let mut entry_1621 = list_1620.entry();
entry_1621.string(item_1619);
}
list_1620.finish();
}
#[allow(unused_mut)]
let mut scope_1622 = writer.prefix("SubnetId");
if let Some(var_1623) = &input.subnet_ids {
let mut list_1625 = scope_1622.start_list(true, Some("item"));
for item_1624 in var_1623 {
#[allow(unused_mut)]
let mut entry_1626 = list_1625.entry();
entry_1626.string(item_1624);
}
list_1625.finish();
}
#[allow(unused_mut)]
let mut scope_1627 = writer.prefix("SecurityGroupId");
if let Some(var_1628) = &input.security_group_ids {
let mut list_1630 = scope_1627.start_list(true, Some("item"));
for item_1629 in var_1628 {
#[allow(unused_mut)]
let mut entry_1631 = list_1630.entry();
entry_1631.string(item_1629);
}
list_1630.finish();
}
#[allow(unused_mut)]
let mut scope_1632 = writer.prefix("IpAddressType");
if let Some(var_1633) = &input.ip_address_type {
scope_1632.string(var_1633.as_str());
}
#[allow(unused_mut)]
let mut scope_1634 = writer.prefix("DnsOptions");
if let Some(var_1635) = &input.dns_options {
crate::query_ser::serialize_structure_crate_model_dns_options_specification(
scope_1634, var_1635,
)?;
}
#[allow(unused_mut)]
let mut scope_1636 = writer.prefix("ClientToken");
if let Some(var_1637) = &input.client_token {
scope_1636.string(var_1637);
}
#[allow(unused_mut)]
let mut scope_1638 = writer.prefix("PrivateDnsEnabled");
if let Some(var_1639) = &input.private_dns_enabled {
scope_1638.boolean(*var_1639);
}
#[allow(unused_mut)]
let mut scope_1640 = writer.prefix("TagSpecification");
if let Some(var_1641) = &input.tag_specifications {
let mut list_1643 = scope_1640.start_list(true, Some("item"));
for item_1642 in var_1641 {
#[allow(unused_mut)]
let mut entry_1644 = list_1643.entry();
crate::query_ser::serialize_structure_crate_model_tag_specification(
entry_1644, item_1642,
)?;
}
list_1643.finish();
}
writer.finish();
Ok(aws_smithy_http::body::SdkBody::from(out))
}
Trait Implementations§
source§impl AsRef<str> for VpcEndpointType
impl AsRef<str> for VpcEndpointType
source§impl Clone for VpcEndpointType
impl Clone for VpcEndpointType
source§fn clone(&self) -> VpcEndpointType
fn clone(&self) -> VpcEndpointType
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for VpcEndpointType
impl Debug for VpcEndpointType
source§impl From<&str> for VpcEndpointType
impl From<&str> for VpcEndpointType
source§impl FromStr for VpcEndpointType
impl FromStr for VpcEndpointType
source§impl Hash for VpcEndpointType
impl Hash for VpcEndpointType
source§impl Ord for VpcEndpointType
impl Ord for VpcEndpointType
source§fn cmp(&self, other: &VpcEndpointType) -> Ordering
fn cmp(&self, other: &VpcEndpointType) -> Ordering
1.21.0 · source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere
Self: Sized,
source§impl PartialEq<VpcEndpointType> for VpcEndpointType
impl PartialEq<VpcEndpointType> for VpcEndpointType
source§fn eq(&self, other: &VpcEndpointType) -> bool
fn eq(&self, other: &VpcEndpointType) -> bool
source§impl PartialOrd<VpcEndpointType> for VpcEndpointType
impl PartialOrd<VpcEndpointType> for VpcEndpointType
source§fn partial_cmp(&self, other: &VpcEndpointType) -> Option<Ordering>
fn partial_cmp(&self, other: &VpcEndpointType) -> Option<Ordering>
1.0.0 · source§fn le(&self, other: &Rhs) -> bool
fn le(&self, other: &Rhs) -> bool
self
and other
) and is used by the <=
operator. Read moreimpl Eq for VpcEndpointType
impl StructuralEq for VpcEndpointType
impl StructuralPartialEq for VpcEndpointType
Auto Trait Implementations§
impl RefUnwindSafe for VpcEndpointType
impl Send for VpcEndpointType
impl Sync for VpcEndpointType
impl Unpin for VpcEndpointType
impl UnwindSafe for VpcEndpointType
Blanket Implementations§
source§impl<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.