chrono

Struct Date

Source
pub struct Date<Tz: TimeZone> { /* private fields */ }
๐Ÿ‘ŽDeprecated since 0.4.23: Use NaiveDate or DateTime<Tz> instead
Expand description

ISO 8601 calendar date with time zone.

You almost certainly want to be using a NaiveDate instead of this type.

This type primarily exists to aid in the construction of DateTimes that have a timezone by way of the TimeZone datelike constructors (e.g. TimeZone::ymd).

This type should be considered ambiguous at best, due to the inherent lack of precision required for the time zone resolution.

There are some guarantees on the usage of Date<Tz>:

  • If properly constructed via TimeZone::ymd and others without an error, the corresponding local date should exist for at least a moment. (It may still have a gap from the offset changes.)

  • The TimeZone is free to assign any Offset to the local date, as long as that offset did occur in given day.

    For example, if 2015-03-08T01:59-08:00 is followed by 2015-03-08T03:00-07:00, it may produce either 2015-03-08-08:00 or 2015-03-08-07:00 but not 2015-03-08+00:00 and others.

  • Once constructed as a full DateTime, DateTime::date and other associated methods should return those for the original Date. For example, if dt = tz.ymd_opt(y,m,d).unwrap().hms(h,n,s) were valid, dt.date() == tz.ymd_opt(y,m,d).unwrap().

  • The date is timezone-agnostic up to one day (i.e. practically always), so the local date and UTC date should be equal for most cases even though the raw calculation between NaiveDate and TimeDelta may not.

Implementationsยง

Sourceยง

impl<Tz: TimeZone> Date<Tz>

Source

pub const MIN_UTC: Date<Utc>

The minimum possible Date.

Source

pub const MAX_UTC: Date<Utc>

The maximum possible Date.

Source

pub fn from_utc(date: NaiveDate, offset: Tz::Offset) -> Date<Tz>

Makes a new Date with given UTC date and offset. The local date should be constructed via the TimeZone trait.

Source

pub fn and_time(&self, time: NaiveTime) -> Option<DateTime<Tz>>

Makes a new DateTime from the current date and given NaiveTime. The offset in the current date is preserved.

Returns None on invalid datetime.

Source

pub fn and_hms(&self, hour: u32, min: u32, sec: u32) -> DateTime<Tz>

๐Ÿ‘ŽDeprecated since 0.4.23: Use and_hms_opt() instead

Makes a new DateTime from the current date, hour, minute and second. The offset in the current date is preserved.

Panics on invalid hour, minute and/or second.

Source

pub fn and_hms_opt(&self, hour: u32, min: u32, sec: u32) -> Option<DateTime<Tz>>

Makes a new DateTime from the current date, hour, minute and second. The offset in the current date is preserved.

Returns None on invalid hour, minute and/or second.

Source

pub fn and_hms_milli( &self, hour: u32, min: u32, sec: u32, milli: u32, ) -> DateTime<Tz>

๐Ÿ‘ŽDeprecated since 0.4.23: Use and_hms_milli_opt() instead

Makes a new DateTime from the current date, hour, minute, second and millisecond. The millisecond part can exceed 1,000 in order to represent the leap second. The offset in the current date is preserved.

Panics on invalid hour, minute, second and/or millisecond.

Source

pub fn and_hms_milli_opt( &self, hour: u32, min: u32, sec: u32, milli: u32, ) -> Option<DateTime<Tz>>

Makes a new DateTime from the current date, hour, minute, second and millisecond. The millisecond part can exceed 1,000 in order to represent the leap second. The offset in the current date is preserved.

Returns None on invalid hour, minute, second and/or millisecond.

Source

pub fn and_hms_micro( &self, hour: u32, min: u32, sec: u32, micro: u32, ) -> DateTime<Tz>

๐Ÿ‘ŽDeprecated since 0.4.23: Use and_hms_micro_opt() instead

Makes a new DateTime from the current date, hour, minute, second and microsecond. The microsecond part can exceed 1,000,000 in order to represent the leap second. The offset in the current date is preserved.

Panics on invalid hour, minute, second and/or microsecond.

Source

pub fn and_hms_micro_opt( &self, hour: u32, min: u32, sec: u32, micro: u32, ) -> Option<DateTime<Tz>>

Makes a new DateTime from the current date, hour, minute, second and microsecond. The microsecond part can exceed 1,000,000 in order to represent the leap second. The offset in the current date is preserved.

Returns None on invalid hour, minute, second and/or microsecond.

Source

pub fn and_hms_nano( &self, hour: u32, min: u32, sec: u32, nano: u32, ) -> DateTime<Tz>

๐Ÿ‘ŽDeprecated since 0.4.23: Use and_hms_nano_opt() instead

Makes a new DateTime from the current date, hour, minute, second and nanosecond. The nanosecond part can exceed 1,000,000,000 in order to represent the leap second. The offset in the current date is preserved.

Panics on invalid hour, minute, second and/or nanosecond.

Source

pub fn and_hms_nano_opt( &self, hour: u32, min: u32, sec: u32, nano: u32, ) -> Option<DateTime<Tz>>

Makes a new DateTime from the current date, hour, minute, second and nanosecond. The nanosecond part can exceed 1,000,000,000 in order to represent the leap second. The offset in the current date is preserved.

Returns None on invalid hour, minute, second and/or nanosecond.

Source

pub fn succ(&self) -> Date<Tz>

๐Ÿ‘ŽDeprecated since 0.4.23: Use succ_opt() instead

Makes a new Date for the next date.

Panics when self is the last representable date.

Source

pub fn succ_opt(&self) -> Option<Date<Tz>>

Makes a new Date for the next date.

Returns None when self is the last representable date.

Source

pub fn pred(&self) -> Date<Tz>

๐Ÿ‘ŽDeprecated since 0.4.23: Use pred_opt() instead

Makes a new Date for the prior date.

Panics when self is the first representable date.

Source

pub fn pred_opt(&self) -> Option<Date<Tz>>

Makes a new Date for the prior date.

Returns None when self is the first representable date.

Source

pub fn offset(&self) -> &Tz::Offset

Retrieves an associated offset from UTC.

Source

pub fn timezone(&self) -> Tz

Retrieves an associated time zone.

Source

pub fn with_timezone<Tz2: TimeZone>(&self, tz: &Tz2) -> Date<Tz2>

Changes the associated time zone. This does not change the actual Date (but will change the string representation).

Source

pub fn checked_add_signed(self, rhs: TimeDelta) -> Option<Date<Tz>>

Adds given TimeDelta to the current date.

Returns None when it will result in overflow.

Source

pub fn checked_sub_signed(self, rhs: TimeDelta) -> Option<Date<Tz>>

Subtracts given TimeDelta from the current date.

Returns None when it will result in overflow.

Source

pub fn signed_duration_since<Tz2: TimeZone>(self, rhs: Date<Tz2>) -> TimeDelta

Subtracts another Date from the current date. Returns a TimeDelta of integral numbers.

This does not overflow or underflow at all, as all possible output fits in the range of TimeDelta.

Source

pub fn naive_utc(&self) -> NaiveDate

Returns a view to the naive UTC date.

Source

pub fn naive_local(&self) -> NaiveDate

Returns a view to the naive local date.

This is technically the same as naive_utc because the offset is restricted to never exceed one day, but provided for the consistency.

Source

pub fn years_since(&self, base: Self) -> Option<u32>

Returns the number of whole years from the given base until self.

Sourceยง

impl<Tz: TimeZone> Date<Tz>
where Tz::Offset: Display,

Source

pub fn format_with_items<'a, I, B>(&self, items: I) -> DelayedFormat<I>
where I: Iterator<Item = B> + Clone, B: Borrow<Item<'a>>,

Available on crate feature alloc only.

Formats the date with the specified formatting items.

Source

pub fn format<'a>(&self, fmt: &'a str) -> DelayedFormat<StrftimeItems<'a>>

Available on crate feature alloc only.

Formats the date with the specified format string. See the crate::format::strftime module on the supported escape sequences.

Trait Implementationsยง

Sourceยง

impl<Tz: TimeZone> Add<TimeDelta> for Date<Tz>

Sourceยง

type Output = Date<Tz>

The resulting type after applying the + operator.
Sourceยง

fn add(self, rhs: TimeDelta) -> Date<Tz>

Performs the + operation. Read more
Sourceยง

impl<Tz: TimeZone> AddAssign<TimeDelta> for Date<Tz>

Sourceยง

fn add_assign(&mut self, rhs: TimeDelta)

Performs the += operation. Read more
Sourceยง

impl<Tz: Clone + TimeZone> Clone for Date<Tz>
where Tz::Offset: Clone,

Sourceยง

fn clone(&self) -> Date<Tz>

Returns a copy of the value. Read more
1.0.0 ยท Sourceยง

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Sourceยง

impl<Tz: TimeZone> Datelike for Date<Tz>

Sourceยง

fn year(&self) -> i32

Returns the year number in the calendar date.
Sourceยง

fn month(&self) -> u32

Returns the month number starting from 1. Read more
Sourceยง

fn month0(&self) -> u32

Returns the month number starting from 0. Read more
Sourceยง

fn day(&self) -> u32

Returns the day of month starting from 1. Read more
Sourceยง

fn day0(&self) -> u32

Returns the day of month starting from 0. Read more
Sourceยง

fn ordinal(&self) -> u32

Returns the day of year starting from 1. Read more
Sourceยง

fn ordinal0(&self) -> u32

Returns the day of year starting from 0. Read more
Sourceยง

fn weekday(&self) -> Weekday

Returns the day of week.
Sourceยง

fn iso_week(&self) -> IsoWeek

Returns the ISO week.
Sourceยง

fn with_year(&self, year: i32) -> Option<Date<Tz>>

Makes a new value with the year number changed, while keeping the same month and day. Read more
Sourceยง

fn with_month(&self, month: u32) -> Option<Date<Tz>>

Makes a new value with the month number (starting from 1) changed. Read more
Sourceยง

fn with_month0(&self, month0: u32) -> Option<Date<Tz>>

Makes a new value with the month number (starting from 0) changed. Read more
Sourceยง

fn with_day(&self, day: u32) -> Option<Date<Tz>>

Makes a new value with the day of month (starting from 1) changed. Read more
Sourceยง

fn with_day0(&self, day0: u32) -> Option<Date<Tz>>

Makes a new value with the day of month (starting from 0) changed. Read more
Sourceยง

fn with_ordinal(&self, ordinal: u32) -> Option<Date<Tz>>

Makes a new value with the day of year (starting from 1) changed. Read more
Sourceยง

fn with_ordinal0(&self, ordinal0: u32) -> Option<Date<Tz>>

Makes a new value with the day of year (starting from 0) changed. Read more
Sourceยง

fn year_ce(&self) -> (bool, u32)

Returns the absolute year number starting from 1 with a boolean flag, which is false when the year predates the epoch (BCE/BC) and true otherwise (CE/AD).
Sourceยง

fn num_days_from_ce(&self) -> i32

Counts the days in the proleptic Gregorian calendar, with January 1, Year 1 (CE) as day 1. Read more
Sourceยง

impl<Tz: TimeZone> Debug for Date<Tz>

Sourceยง

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Sourceยง

impl<Tz: TimeZone> Display for Date<Tz>
where Tz::Offset: Display,

Sourceยง

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Sourceยง

impl<Tz: TimeZone> Hash for Date<Tz>

Sourceยง

fn hash<H: Hasher>(&self, state: &mut H)

Feeds this value into the given Hasher. Read more
1.3.0 ยท Sourceยง

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Sourceยง

impl<Tz: TimeZone> Ord for Date<Tz>

Sourceยง

fn cmp(&self, other: &Date<Tz>) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 ยท Sourceยง

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 ยท Sourceยง

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 ยท Sourceยง

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized,

Restrict a value to a certain interval. Read more
Sourceยง

impl<Tz: TimeZone, Tz2: TimeZone> PartialEq<Date<Tz2>> for Date<Tz>

Sourceยง

fn eq(&self, other: &Date<Tz2>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 ยท Sourceยง

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Sourceยง

impl<Tz: TimeZone> PartialOrd for Date<Tz>

Sourceยง

fn partial_cmp(&self, other: &Date<Tz>) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 ยท Sourceยง

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 ยท Sourceยง

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 ยท Sourceยง

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 ยท Sourceยง

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
Sourceยง

impl<Tz: TimeZone> Sub<TimeDelta> for Date<Tz>

Sourceยง

type Output = Date<Tz>

The resulting type after applying the - operator.
Sourceยง

fn sub(self, rhs: TimeDelta) -> Date<Tz>

Performs the - operation. Read more
Sourceยง

impl<Tz: TimeZone> Sub for Date<Tz>

Sourceยง

type Output = TimeDelta

The resulting type after applying the - operator.
Sourceยง

fn sub(self, rhs: Date<Tz>) -> TimeDelta

Performs the - operation. Read more
Sourceยง

impl<Tz: TimeZone> SubAssign<TimeDelta> for Date<Tz>

Sourceยง

fn sub_assign(&mut self, rhs: TimeDelta)

Performs the -= operation. Read more
Sourceยง

impl<Tz: TimeZone> Copy for Date<Tz>
where <Tz as TimeZone>::Offset: Copy,

Sourceยง

impl<Tz: TimeZone> Eq for Date<Tz>

Sourceยง

impl<Tz: TimeZone> Send for Date<Tz>
where <Tz as TimeZone>::Offset: Send,

Auto Trait Implementationsยง

ยง

impl<Tz> Freeze for Date<Tz>
where <Tz as TimeZone>::Offset: Freeze,

ยง

impl<Tz> RefUnwindSafe for Date<Tz>
where <Tz as TimeZone>::Offset: RefUnwindSafe,

ยง

impl<Tz> Sync for Date<Tz>
where <Tz as TimeZone>::Offset: Sync,

ยง

impl<Tz> Unpin for Date<Tz>
where <Tz as TimeZone>::Offset: Unpin,

ยง

impl<Tz> UnwindSafe for Date<Tz>
where <Tz as TimeZone>::Offset: UnwindSafe,

Blanket Implementationsยง

Sourceยง

impl<T> Any for T
where T: 'static + ?Sized,

Sourceยง

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Sourceยง

impl<T> Borrow<T> for T
where T: ?Sized,

Sourceยง

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Sourceยง

impl<T> BorrowMut<T> for T
where T: ?Sized,

Sourceยง

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Sourceยง

impl<T> CloneToUninit for T
where T: Clone,

Sourceยง

unsafe fn clone_to_uninit(&self, dst: *mut u8)

๐Ÿ”ฌThis is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
Sourceยง

impl<T> From<T> for T

Sourceยง

fn from(t: T) -> T

Returns the argument unchanged.

Sourceยง

impl<T, U> Into<U> for T
where U: From<T>,

Sourceยง

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Sourceยง

impl<T> ToOwned for T
where T: Clone,

Sourceยง

type Owned = T

The resulting type after obtaining ownership.
Sourceยง

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Sourceยง

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Sourceยง

impl<T> ToString for T
where T: Display + ?Sized,

Sourceยง

fn to_string(&self) -> String

Converts the given value to a String. Read more
Sourceยง

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Sourceยง

type Error = Infallible

The type returned in the event of a conversion error.
Sourceยง

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Sourceยง

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Sourceยง

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Sourceยง

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.

Layoutยง

Note: Unable to compute type layout, possibly due to this type having generic parameters. Layout can only be computed for concrete, fully-instantiated types.