#[non_exhaustive]
pub enum InstanceMetadataEndpointState {
Disabled,
Enabled,
Unknown(UnknownVariantValue),
}
Expand description
When writing a match expression against InstanceMetadataEndpointState
, 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 instancemetadataendpointstate = unimplemented!();
match instancemetadataendpointstate {
InstanceMetadataEndpointState::Disabled => { /* ... */ },
InstanceMetadataEndpointState::Enabled => { /* ... */ },
other @ _ if other.as_str() == "NewFeature" => { /* handles a case for `NewFeature` */ },
_ => { /* ... */ },
}
The above code demonstrates that when instancemetadataendpointstate
represents
NewFeature
, the execution path will lead to the second last match arm,
even though the enum does not contain a variant InstanceMetadataEndpointState::NewFeature
in the current version of SDK. The reason is that the variable other
,
created by the @
operator, is bound to
InstanceMetadataEndpointState::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 InstanceMetadataEndpointState::NewFeature
is defined.
Specifically, when instancemetadataendpointstate
represents NewFeature
,
the execution path will hit the second last match arm as before by virtue of
calling as_str
on InstanceMetadataEndpointState::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
Disabled
Enabled
Unknown(UnknownVariantValue)
Unknown
contains new variants that have been added since this code was generated.
Implementations§
source§impl InstanceMetadataEndpointState
impl InstanceMetadataEndpointState
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
3534 3535 3536 3537 3538 3539 3540 3541 3542 3543 3544 3545 3546 3547 3548 3549 3550 3551 3552 3553 3554 3555 3556 3557 3558 3559 3560 3561 3562 3563 3564 3565 3566 3567
pub fn serialize_structure_crate_model_instance_metadata_options_request(
mut writer: aws_smithy_query::QueryValueWriter,
input: &crate::model::InstanceMetadataOptionsRequest,
) -> Result<(), aws_smithy_http::operation::error::SerializationError> {
#[allow(unused_mut)]
let mut scope_1017 = writer.prefix("HttpTokens");
if let Some(var_1018) = &input.http_tokens {
scope_1017.string(var_1018.as_str());
}
#[allow(unused_mut)]
let mut scope_1019 = writer.prefix("HttpPutResponseHopLimit");
if let Some(var_1020) = &input.http_put_response_hop_limit {
scope_1019.number(
#[allow(clippy::useless_conversion)]
aws_smithy_types::Number::NegInt((*var_1020).into()),
);
}
#[allow(unused_mut)]
let mut scope_1021 = writer.prefix("HttpEndpoint");
if let Some(var_1022) = &input.http_endpoint {
scope_1021.string(var_1022.as_str());
}
#[allow(unused_mut)]
let mut scope_1023 = writer.prefix("HttpProtocolIpv6");
if let Some(var_1024) = &input.http_protocol_ipv6 {
scope_1023.string(var_1024.as_str());
}
#[allow(unused_mut)]
let mut scope_1025 = writer.prefix("InstanceMetadataTags");
if let Some(var_1026) = &input.instance_metadata_tags {
scope_1025.string(var_1026.as_str());
}
Ok(())
}
18029 18030 18031 18032 18033 18034 18035 18036 18037 18038 18039 18040 18041 18042 18043 18044 18045 18046 18047 18048 18049 18050 18051 18052 18053 18054 18055 18056 18057 18058 18059 18060 18061 18062 18063 18064 18065 18066 18067 18068 18069 18070 18071 18072 18073 18074 18075 18076
pub fn serialize_operation_crate_operation_modify_instance_metadata_options(
input: &crate::input::ModifyInstanceMetadataOptionsInput,
) -> 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, "ModifyInstanceMetadataOptions", "2016-11-15");
#[allow(unused_mut)]
let mut scope_5068 = writer.prefix("InstanceId");
if let Some(var_5069) = &input.instance_id {
scope_5068.string(var_5069);
}
#[allow(unused_mut)]
let mut scope_5070 = writer.prefix("HttpTokens");
if let Some(var_5071) = &input.http_tokens {
scope_5070.string(var_5071.as_str());
}
#[allow(unused_mut)]
let mut scope_5072 = writer.prefix("HttpPutResponseHopLimit");
if let Some(var_5073) = &input.http_put_response_hop_limit {
scope_5072.number(
#[allow(clippy::useless_conversion)]
aws_smithy_types::Number::NegInt((*var_5073).into()),
);
}
#[allow(unused_mut)]
let mut scope_5074 = writer.prefix("HttpEndpoint");
if let Some(var_5075) = &input.http_endpoint {
scope_5074.string(var_5075.as_str());
}
#[allow(unused_mut)]
let mut scope_5076 = writer.prefix("DryRun");
if let Some(var_5077) = &input.dry_run {
scope_5076.boolean(*var_5077);
}
#[allow(unused_mut)]
let mut scope_5078 = writer.prefix("HttpProtocolIpv6");
if let Some(var_5079) = &input.http_protocol_ipv6 {
scope_5078.string(var_5079.as_str());
}
#[allow(unused_mut)]
let mut scope_5080 = writer.prefix("InstanceMetadataTags");
if let Some(var_5081) = &input.instance_metadata_tags {
scope_5080.string(var_5081.as_str());
}
writer.finish();
Ok(aws_smithy_http::body::SdkBody::from(out))
}
Trait Implementations§
source§impl AsRef<str> for InstanceMetadataEndpointState
impl AsRef<str> for InstanceMetadataEndpointState
source§impl Clone for InstanceMetadataEndpointState
impl Clone for InstanceMetadataEndpointState
source§fn clone(&self) -> InstanceMetadataEndpointState
fn clone(&self) -> InstanceMetadataEndpointState
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl From<&str> for InstanceMetadataEndpointState
impl From<&str> for InstanceMetadataEndpointState
source§impl Hash for InstanceMetadataEndpointState
impl Hash for InstanceMetadataEndpointState
source§impl Ord for InstanceMetadataEndpointState
impl Ord for InstanceMetadataEndpointState
source§fn cmp(&self, other: &InstanceMetadataEndpointState) -> Ordering
fn cmp(&self, other: &InstanceMetadataEndpointState) -> Ordering
1.21.0 · source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere
Self: Sized,
source§impl PartialEq<InstanceMetadataEndpointState> for InstanceMetadataEndpointState
impl PartialEq<InstanceMetadataEndpointState> for InstanceMetadataEndpointState
source§fn eq(&self, other: &InstanceMetadataEndpointState) -> bool
fn eq(&self, other: &InstanceMetadataEndpointState) -> bool
source§impl PartialOrd<InstanceMetadataEndpointState> for InstanceMetadataEndpointState
impl PartialOrd<InstanceMetadataEndpointState> for InstanceMetadataEndpointState
source§fn partial_cmp(&self, other: &InstanceMetadataEndpointState) -> Option<Ordering>
fn partial_cmp(&self, other: &InstanceMetadataEndpointState) -> 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 InstanceMetadataEndpointState
impl StructuralEq for InstanceMetadataEndpointState
impl StructuralPartialEq for InstanceMetadataEndpointState
Auto Trait Implementations§
impl RefUnwindSafe for InstanceMetadataEndpointState
impl Send for InstanceMetadataEndpointState
impl Sync for InstanceMetadataEndpointState
impl Unpin for InstanceMetadataEndpointState
impl UnwindSafe for InstanceMetadataEndpointState
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.