#[non_exhaustive]pub enum AutoAcceptSharedAttachmentsValue {
Disable,
Enable,
Unknown(UnknownVariantValue),
}
Expand description
When writing a match expression against AutoAcceptSharedAttachmentsValue
, 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 autoacceptsharedattachmentsvalue = unimplemented!();
match autoacceptsharedattachmentsvalue {
AutoAcceptSharedAttachmentsValue::Disable => { /* ... */ },
AutoAcceptSharedAttachmentsValue::Enable => { /* ... */ },
other @ _ if other.as_str() == "NewFeature" => { /* handles a case for `NewFeature` */ },
_ => { /* ... */ },
}
The above code demonstrates that when autoacceptsharedattachmentsvalue
represents
NewFeature
, the execution path will lead to the second last match arm,
even though the enum does not contain a variant AutoAcceptSharedAttachmentsValue::NewFeature
in the current version of SDK. The reason is that the variable other
,
created by the @
operator, is bound to
AutoAcceptSharedAttachmentsValue::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 AutoAcceptSharedAttachmentsValue::NewFeature
is defined.
Specifically, when autoacceptsharedattachmentsvalue
represents NewFeature
,
the execution path will hit the second last match arm as before by virtue of
calling as_str
on AutoAcceptSharedAttachmentsValue::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
Disable
Enable
Unknown(UnknownVariantValue)
Unknown
contains new variants that have been added since this code was generated.
Implementations§
Trait Implementations§
source§fn clone(&self) -> AutoAcceptSharedAttachmentsValue
fn clone(&self) -> AutoAcceptSharedAttachmentsValue
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§fn cmp(&self, other: &AutoAcceptSharedAttachmentsValue) -> Ordering
fn cmp(&self, other: &AutoAcceptSharedAttachmentsValue) -> Ordering
1.21.0 · source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere Self: Sized,
source§fn eq(&self, other: &AutoAcceptSharedAttachmentsValue) -> bool
fn eq(&self, other: &AutoAcceptSharedAttachmentsValue) -> bool
self
and other
values to be equal, and is used
by ==
.source§fn partial_cmp(
&self,
other: &AutoAcceptSharedAttachmentsValue
) -> Option<Ordering>
fn partial_cmp( &self, other: &AutoAcceptSharedAttachmentsValue ) -> 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 moreAuto Trait Implementations§
Blanket Implementations§
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.