#[non_exhaustive]pub enum ShareRequestStatus {
    Active,
    Declined,
    Expired,
    Expiring,
    Failed,
    Replicating,
    Revoked,
    Shared,
    Unknown(UnknownVariantValue),
}Expand description
When writing a match expression against ShareRequestStatus, 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 sharerequeststatus = unimplemented!();
match sharerequeststatus {
    ShareRequestStatus::Active => { /* ... */ },
    ShareRequestStatus::Declined => { /* ... */ },
    ShareRequestStatus::Expired => { /* ... */ },
    ShareRequestStatus::Expiring => { /* ... */ },
    ShareRequestStatus::Failed => { /* ... */ },
    ShareRequestStatus::Replicating => { /* ... */ },
    ShareRequestStatus::Revoked => { /* ... */ },
    ShareRequestStatus::Shared => { /* ... */ },
    other @ _ if other.as_str() == "NewFeature" => { /* handles a case for `NewFeature` */ },
    _ => { /* ... */ },
}
The above code demonstrates that when sharerequeststatus represents
NewFeature, the execution path will lead to the second last match arm,
even though the enum does not contain a variant ShareRequestStatus::NewFeature
in the current version of SDK. The reason is that the variable other,
created by the @ operator, is bound to
ShareRequestStatus::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 ShareRequestStatus::NewFeature is defined.
Specifically, when sharerequeststatus represents NewFeature,
the execution path will hit the second last match arm as before by virtue of
calling as_str on ShareRequestStatus::NewFeature also yielding "NewFeature".
Explicitly matching on the Unknown variant should
be avoided for two reasons:
- The inner data UnknownVariantValueis 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
Active
Declined
Expired
Expiring
Failed
Replicating
Revoked
Unknown(UnknownVariantValue)
Unknown contains new variants that have been added since this code was generated.
Implementations§
Trait Implementations§
source§fn clone(&self) -> ShareRequestStatus
 
fn clone(&self) -> ShareRequestStatus
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: &ShareRequestStatus) -> Ordering
 
fn cmp(&self, other: &ShareRequestStatus) -> 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: &ShareRequestStatus) -> bool
 
fn eq(&self, other: &ShareRequestStatus) -> bool
self and other values to be equal, and is used
by ==.source§fn partial_cmp(&self, other: &ShareRequestStatus) -> Option<Ordering>
 
fn partial_cmp(&self, other: &ShareRequestStatus) -> 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.