Enum aws_sdk_transcribe::model::SentimentValue
source · #[non_exhaustive]
pub enum SentimentValue {
Mixed,
Negative,
Neutral,
Positive,
Unknown(UnknownVariantValue),
}Expand description
When writing a match expression against SentimentValue, 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 sentimentvalue = unimplemented!();
match sentimentvalue {
SentimentValue::Mixed => { /* ... */ },
SentimentValue::Negative => { /* ... */ },
SentimentValue::Neutral => { /* ... */ },
SentimentValue::Positive => { /* ... */ },
other @ _ if other.as_str() == "NewFeature" => { /* handles a case for `NewFeature` */ },
_ => { /* ... */ },
}
The above code demonstrates that when sentimentvalue represents
NewFeature, the execution path will lead to the second last match arm,
even though the enum does not contain a variant SentimentValue::NewFeature
in the current version of SDK. The reason is that the variable other,
created by the @ operator, is bound to
SentimentValue::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 SentimentValue::NewFeature is defined.
Specifically, when sentimentvalue represents NewFeature,
the execution path will hit the second last match arm as before by virtue of
calling as_str on SentimentValue::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
Mixed
Negative
Neutral
Positive
Unknown(UnknownVariantValue)
Unknown contains new variants that have been added since this code was generated.
Implementations§
source§impl SentimentValue
impl SentimentValue
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
1323 1324 1325 1326 1327 1328 1329 1330 1331 1332 1333 1334 1335 1336 1337 1338 1339 1340 1341 1342 1343 1344 1345 1346 1347 1348 1349 1350 1351 1352 1353 1354 1355 1356 1357 1358 1359 1360 1361
pub fn serialize_structure_crate_model_sentiment_filter(
object: &mut aws_smithy_json::serialize::JsonObjectWriter,
input: &crate::model::SentimentFilter,
) -> Result<(), aws_smithy_http::operation::error::SerializationError> {
if let Some(var_265) = &input.sentiments {
let mut array_266 = object.key("Sentiments").start_array();
for item_267 in var_265 {
{
array_266.value().string(item_267.as_str());
}
}
array_266.finish();
}
if let Some(var_268) = &input.absolute_time_range {
#[allow(unused_mut)]
let mut object_269 = object.key("AbsoluteTimeRange").start_object();
crate::json_ser::serialize_structure_crate_model_absolute_time_range(
&mut object_269,
var_268,
)?;
object_269.finish();
}
if let Some(var_270) = &input.relative_time_range {
#[allow(unused_mut)]
let mut object_271 = object.key("RelativeTimeRange").start_object();
crate::json_ser::serialize_structure_crate_model_relative_time_range(
&mut object_271,
var_270,
)?;
object_271.finish();
}
if let Some(var_272) = &input.participant_role {
object.key("ParticipantRole").string(var_272.as_str());
}
if let Some(var_273) = &input.negate {
object.key("Negate").boolean(*var_273);
}
Ok(())
}Trait Implementations§
source§impl AsRef<str> for SentimentValue
impl AsRef<str> for SentimentValue
source§impl Clone for SentimentValue
impl Clone for SentimentValue
source§fn clone(&self) -> SentimentValue
fn clone(&self) -> SentimentValue
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moresource§impl Debug for SentimentValue
impl Debug for SentimentValue
source§impl From<&str> for SentimentValue
impl From<&str> for SentimentValue
source§impl FromStr for SentimentValue
impl FromStr for SentimentValue
source§impl Hash for SentimentValue
impl Hash for SentimentValue
source§impl Ord for SentimentValue
impl Ord for SentimentValue
source§fn cmp(&self, other: &SentimentValue) -> Ordering
fn cmp(&self, other: &SentimentValue) -> Ordering
1.21.0 · source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere
Self: Sized,
source§impl PartialEq<SentimentValue> for SentimentValue
impl PartialEq<SentimentValue> for SentimentValue
source§fn eq(&self, other: &SentimentValue) -> bool
fn eq(&self, other: &SentimentValue) -> bool
source§impl PartialOrd<SentimentValue> for SentimentValue
impl PartialOrd<SentimentValue> for SentimentValue
source§fn partial_cmp(&self, other: &SentimentValue) -> Option<Ordering>
fn partial_cmp(&self, other: &SentimentValue) -> 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 SentimentValue
impl StructuralEq for SentimentValue
impl StructuralPartialEq for SentimentValue
Auto Trait Implementations§
impl RefUnwindSafe for SentimentValue
impl Send for SentimentValue
impl Sync for SentimentValue
impl Unpin for SentimentValue
impl UnwindSafe for SentimentValue
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.