pub struct SpanParser { /* private fields */ }
Expand description
A parser for Temporal durations.
Note that in Jiff, a “Temporal duration” is called a “span.”
See the fmt::temporal
module documentation for
more information on the specific format used.
§Example
This example shows how to parse a Span
from a byte string. (That is,
&[u8]
and not a &str
.)
use jiff::{fmt::temporal::SpanParser, ToSpan};
// A parser can be created in a const context.
static PARSER: SpanParser = SpanParser::new();
let span = PARSER.parse_span(b"P3y7m25dT7h36m")?;
assert_eq!(
span,
3.years().months(7).days(25).hours(7).minutes(36).fieldwise(),
);
Implementations§
Source§impl SpanParser
impl SpanParser
Sourcepub const fn new() -> SpanParser
pub const fn new() -> SpanParser
Create a new Temporal datetime printer with the default configuration.
Sourcepub fn parse_span<I>(&self, input: I) -> Result<Span, Error>
pub fn parse_span<I>(&self, input: I) -> Result<Span, Error>
Parse a span string into a Span
value.
§Errors
This returns an error if the span string given is invalid or if it is valid but doesn’t fit in the span range supported by Jiff.
§Example
This shows a basic example of using this routine.
use jiff::{fmt::temporal::SpanParser, ToSpan};
static PARSER: SpanParser = SpanParser::new();
let span = PARSER.parse_span(b"PT48m")?;
assert_eq!(span, 48.minutes().fieldwise());
Note that unless you need to parse a span from a byte string,
at time of writing, there is no other advantage to using this
parser directly. It is likely more convenient to just use the
FromStr
trait implementation on Span
:
use jiff::{Span, ToSpan};
let span = "PT48m".parse::<Span>()?;
assert_eq!(span, 48.minutes().fieldwise());
Sourcepub fn parse_duration<I>(&self, input: I) -> Result<SignedDuration, Error>
pub fn parse_duration<I>(&self, input: I) -> Result<SignedDuration, Error>
Parse an ISO 8601 duration string into a SignedDuration
value.
§Errors
This returns an error if the span string given is invalid or if it is
valid but can’t be converted to a SignedDuration
. This can occur
when the parsed time exceeds the minimum and maximum SignedDuration
values, or if there are any non-zero units greater than hours.
§Example
This shows a basic example of using this routine.
use jiff::{fmt::temporal::SpanParser, SignedDuration};
static PARSER: SpanParser = SpanParser::new();
let duration = PARSER.parse_duration(b"PT48m")?;
assert_eq!(duration, SignedDuration::from_mins(48));
Note that unless you need to parse a span from a byte string,
at time of writing, there is no other advantage to using this
parser directly. It is likely more convenient to just use
the FromStr
trait implementation on
SignedDuration
:
use jiff::SignedDuration;
let duration = "PT48m".parse::<SignedDuration>()?;
assert_eq!(duration, SignedDuration::from_mins(48));
Trait Implementations§
Auto Trait Implementations§
impl Freeze for SpanParser
impl RefUnwindSafe for SpanParser
impl Send for SpanParser
impl Sync for SpanParser
impl Unpin for SpanParser
impl UnwindSafe for SpanParser
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
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
Source§fn in_current_span(self) -> Instrumented<Self> ⓘ
fn in_current_span(self) -> Instrumented<Self> ⓘ
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> ⓘ
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> ⓘ
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