#[non_exhaustive]pub enum Time {
Full,
Long,
Medium,
Short,
}
Expand description
Represents different length lengths a for datetime formatting. Each length has associated best pattern for it for a given locale.
§Examples
use icu::datetime::options::length;
let bag = length::Bag::from_time_style(length::Time::Medium);
The available lengths correspond to UTS #35: Unicode LDML 4. Dates
, section 2.4 [Element timeFormats
].
Note: The exact result returned from using these lengths is a subject to change over time. Formatted result should be treated as opaque and displayed to the user as-is, and it is strongly recommended to never write tests that expect a particular formatted output.
Variants (Non-exhaustive)§
This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
Full
Full length, with spelled out time zone name.
§Examples
- 8:25:07 AM Pacific Standard Time (
en-US
) - 08:25:07 czas pacyficzny standardowy (
pl
) - ٨:٢٥:٠٧ ص توقيت المحيط الهادي الرسمي (
ar
) - 08:25:07 Тихоокеанское стандартное время (
ru
) - 8時25分07秒 アメリカ太平洋標準時 (
ja
)
Long
Full length, usually with short time-zone code.
§Examples
- 8:25:07 AM PST (
en-US
) - 08:25:07 GMT-8 (
pl
) - ٨:٢٥:٠٧ ص غرينتش-٨ (
ar
) - 08:25:07 GMT-8 (
ru
) - 8:25:07 GMT-8 (
ja
)
Medium
Full length, usually with seconds.
§Examples
- 8:25:07 AM (
en-US
) - 08:25:07 (
pl
) - ٨:٢٥:٠٧ ص (
ar
) - 08:25:07 (
ru
) - 8:25:07 (
ja
)
Short
Full length, usually without seconds.
§Examples
- 8:25 AM (
en-US
) - 08:25 (
pl
) - ٨:٢٥ ص (
ar
) - 08:25 (
ru
) - 8:25 (
ja
)
Trait Implementations§
source§impl<'de> Deserialize<'de> for Time
impl<'de> Deserialize<'de> for Time
source§fn deserialize<__D>(
__deserializer: __D,
) -> Result<Time, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(
__deserializer: __D,
) -> Result<Time, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
source§impl Serialize for Time
impl Serialize for Time
source§fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
Serialize this value into the given Serde serializer. Read more
impl Copy for Time
impl Eq for Time
impl StructuralPartialEq for Time
Auto Trait Implementations§
impl Freeze for Time
impl RefUnwindSafe for Time
impl Send for Time
impl Sync for Time
impl Unpin for Time
impl UnwindSafe for Time
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit
)source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more