#[non_exhaustive]
pub enum UnavailabilityReasonCode {
InvalidClassificationResult,
ObjectExceedsSizeQuota,
ObjectUnavailable,
UnsupportedFindingType,
UnsupportedObjectType,
Unknown(UnknownVariantValue),
}Expand description
When writing a match expression against UnavailabilityReasonCode, 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 unavailabilityreasoncode = unimplemented!();
match unavailabilityreasoncode {
UnavailabilityReasonCode::InvalidClassificationResult => { /* ... */ },
UnavailabilityReasonCode::ObjectExceedsSizeQuota => { /* ... */ },
UnavailabilityReasonCode::ObjectUnavailable => { /* ... */ },
UnavailabilityReasonCode::UnsupportedFindingType => { /* ... */ },
UnavailabilityReasonCode::UnsupportedObjectType => { /* ... */ },
other @ _ if other.as_str() == "NewFeature" => { /* handles a case for `NewFeature` */ },
_ => { /* ... */ },
}
The above code demonstrates that when unavailabilityreasoncode represents
NewFeature, the execution path will lead to the second last match arm,
even though the enum does not contain a variant UnavailabilityReasonCode::NewFeature
in the current version of SDK. The reason is that the variable other,
created by the @ operator, is bound to
UnavailabilityReasonCode::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 UnavailabilityReasonCode::NewFeature is defined.
Specifically, when unavailabilityreasoncode represents NewFeature,
the execution path will hit the second last match arm as before by virtue of
calling as_str on UnavailabilityReasonCode::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.
Specifies why occurrences of sensitive data can't be retrieved for a finding. Possible values are:
Variants (Non-exhaustive)§
This enum is marked as non-exhaustive
InvalidClassificationResult
ObjectExceedsSizeQuota
UnsupportedFindingType
UnsupportedObjectType
Unknown(UnknownVariantValue)
Unknown contains new variants that have been added since this code was generated.
Implementations§
Trait Implementations§
source§fn clone(&self) -> UnavailabilityReasonCode
fn clone(&self) -> UnavailabilityReasonCode
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: &UnavailabilityReasonCode) -> Ordering
fn cmp(&self, other: &UnavailabilityReasonCode) -> 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: &UnavailabilityReasonCode) -> bool
fn eq(&self, other: &UnavailabilityReasonCode) -> bool
self and other values to be equal, and is used
by ==.source§fn partial_cmp(&self, other: &UnavailabilityReasonCode) -> Option<Ordering>
fn partial_cmp(&self, other: &UnavailabilityReasonCode) -> 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 equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key and return true if they are equal.