Struct time::format_description::well_known::iso8601::Iso8601
source · pub struct Iso8601<const CONFIG: EncodedConfig = { Config::DEFAULT.encode() }>;
Expand description
The format described in ISO 8601.
This implementation is of ISO 8601-1:2019. It may not be compatible with other versions.
The const parameter CONFIG
must be a value that was returned by Config::encode
.
Passing any other value is unspecified behavior.
Example: 1997-11-21T09:55:06.000000000-06:00
§Examples
assert_eq!(
datetime!(1997-11-12 9:55:06 -6:00).format(&Iso8601::DEFAULT)?,
"1997-11-12T09:55:06.000000000-06:00"
);
RunImplementations§
source§impl<const CONFIG: EncodedConfig> Iso8601<CONFIG>
impl<const CONFIG: EncodedConfig> Iso8601<CONFIG>
sourcepub(crate) const FORMAT_DATE: bool = _
pub(crate) const FORMAT_DATE: bool = _
Whether the date should be formatted.
sourcepub(crate) const FORMAT_TIME: bool = _
pub(crate) const FORMAT_TIME: bool = _
Whether the time should be formatted.
sourcepub(crate) const FORMAT_OFFSET: bool = _
pub(crate) const FORMAT_OFFSET: bool = _
Whether the UTC offset should be formatted.
sourcepub(crate) const YEAR_IS_SIX_DIGITS: bool = _
pub(crate) const YEAR_IS_SIX_DIGITS: bool = _
Whether the year is six digits.
sourcepub(crate) const USE_SEPARATORS: bool = _
pub(crate) const USE_SEPARATORS: bool = _
Whether the format contains separators (such as -
or :
).
sourcepub(crate) const TIME_PRECISION: TimePrecision = _
pub(crate) const TIME_PRECISION: TimePrecision = _
The precision and number of decimal digits to use for the time.
sourcepub(crate) const OFFSET_PRECISION: OffsetPrecision = _
pub(crate) const OFFSET_PRECISION: OffsetPrecision = _
The precision for the UTC offset.
source§impl Iso8601<DEFAULT>
impl Iso8601<DEFAULT>
sourcepub const DEFAULT: Self = Self
pub const DEFAULT: Self = Self
An Iso8601
with the default configuration.
The following is the default behavior:
- The configuration can be used for both formatting and parsing.
- The date, time, and UTC offset are all formatted.
- Separators (such as
-
and:
) are included. - The year contains four digits, such that the year must be between 0 and 9999.
- The date uses the calendar format.
- The time has precision to the second and nine decimal digits.
- The UTC offset has precision to the minute.
If you need different behavior, use another associated constant. For full customization, use
Config::DEFAULT
and Config
’s methods to create a custom configuration.
source§impl Iso8601<DATE>
impl Iso8601<DATE>
sourcepub const DATE: Self = Self
pub const DATE: Self = Self
An Iso8601
that handles only the date, but is otherwise the same as Config::DEFAULT
.
source§impl Iso8601<TIME>
impl Iso8601<TIME>
sourcepub const TIME: Self = Self
pub const TIME: Self = Self
An Iso8601
that handles only the time, but is otherwise the same as Config::DEFAULT
.
source§impl Iso8601<OFFSET>
impl Iso8601<OFFSET>
sourcepub const OFFSET: Self = Self
pub const OFFSET: Self = Self
An Iso8601
that handles only the UTC offset, but is otherwise the same as
Config::DEFAULT
.
source§impl Iso8601<DATE_TIME>
impl Iso8601<DATE_TIME>
sourcepub const DATE_TIME: Self = Self
pub const DATE_TIME: Self = Self
An Iso8601
that handles the date and time, but is otherwise the same as
Config::DEFAULT
.
source§impl Iso8601<DATE_TIME_OFFSET>
impl Iso8601<DATE_TIME_OFFSET>
sourcepub const DATE_TIME_OFFSET: Self = Self
pub const DATE_TIME_OFFSET: Self = Self
An Iso8601
that handles the date, time, and UTC offset. This is the same as
Config::DEFAULT
.
source§impl Iso8601<TIME_OFFSET>
impl Iso8601<TIME_OFFSET>
sourcepub const TIME_OFFSET: Self = Self
pub const TIME_OFFSET: Self = Self
An Iso8601
that handles the time and UTC offset, but is otherwise the same as
Config::DEFAULT
.
source§impl<const CONFIG: EncodedConfig> Iso8601<CONFIG>
impl<const CONFIG: EncodedConfig> Iso8601<CONFIG>
sourcepub(crate) fn parse_date<'a>(
parsed: &'a mut Parsed,
extended_kind: &'a mut ExtendedKind,
) -> impl FnMut(&[u8]) -> Result<&[u8], Parse> + 'a
pub(crate) fn parse_date<'a>( parsed: &'a mut Parsed, extended_kind: &'a mut ExtendedKind, ) -> impl FnMut(&[u8]) -> Result<&[u8], Parse> + 'a
Parse a date in the basic or extended format. Reduced precision is permitted.
sourcepub(crate) fn parse_time<'a>(
parsed: &'a mut Parsed,
extended_kind: &'a mut ExtendedKind,
date_is_present: bool,
) -> impl FnMut(&[u8]) -> Result<&[u8], Parse> + 'a
pub(crate) fn parse_time<'a>( parsed: &'a mut Parsed, extended_kind: &'a mut ExtendedKind, date_is_present: bool, ) -> impl FnMut(&[u8]) -> Result<&[u8], Parse> + 'a
Parse a time in the basic or extended format. Reduced precision is permitted.
sourcepub(crate) fn parse_offset<'a>(
parsed: &'a mut Parsed,
extended_kind: &'a mut ExtendedKind,
) -> impl FnMut(&[u8]) -> Result<&[u8], Parse> + 'a
pub(crate) fn parse_offset<'a>( parsed: &'a mut Parsed, extended_kind: &'a mut ExtendedKind, ) -> impl FnMut(&[u8]) -> Result<&[u8], Parse> + 'a
Parse a UTC offset in the basic or extended format. Reduced precision is supported.
Trait Implementations§
source§impl<const CONFIG: EncodedConfig> Clone for Iso8601<CONFIG>
impl<const CONFIG: EncodedConfig> Clone for Iso8601<CONFIG>
source§impl<const CONFIG: EncodedConfig> Debug for Iso8601<CONFIG>
impl<const CONFIG: EncodedConfig> Debug for Iso8601<CONFIG>
source§impl<const CONFIG: EncodedConfig> PartialEq for Iso8601<CONFIG>
impl<const CONFIG: EncodedConfig> PartialEq for Iso8601<CONFIG>
source§impl<const CONFIG: EncodedConfig> Sealed for Iso8601<CONFIG>
impl<const CONFIG: EncodedConfig> Sealed for Iso8601<CONFIG>
source§fn parse_date(&self, input: &[u8]) -> Result<Date, Parse>
fn parse_date(&self, input: &[u8]) -> Result<Date, Parse>
Date
from the format description.source§fn parse_time(&self, input: &[u8]) -> Result<Time, Parse>
fn parse_time(&self, input: &[u8]) -> Result<Time, Parse>
Time
from the format description.source§fn parse_offset(&self, input: &[u8]) -> Result<UtcOffset, Parse>
fn parse_offset(&self, input: &[u8]) -> Result<UtcOffset, Parse>
UtcOffset
from the format description.source§fn parse_primitive_date_time(
&self,
input: &[u8],
) -> Result<PrimitiveDateTime, Parse>
fn parse_primitive_date_time( &self, input: &[u8], ) -> Result<PrimitiveDateTime, Parse>
PrimitiveDateTime
from the format description.source§fn parse_offset_date_time(&self, input: &[u8]) -> Result<OffsetDateTime, Parse>
fn parse_offset_date_time(&self, input: &[u8]) -> Result<OffsetDateTime, Parse>
OffsetDateTime
from the format description.