pub struct YmdHms { /* private fields */ }Expand description
Combined Gregorian date + wall time with subsecond precision.
Has calendar aware and, when the jiff-tz feature is enabled,
timezone aware math functions.
§Examples
Creating a YmdHms.
use deep_time::{Dt, Scale};
// clamped to 29
let x = Dt::from_ymd(2000, 2, 30, 0, 0, 0, 0, Scale::UTC).to_ymd();
assert_eq!(x.day(), 29);Adding a year. 2000 is a leap year and Feb. 29th is possible, but 2001 isn’t a leap year so the day is clamped to the 28th.
use deep_time::{Dt, Scale};
let x = Dt::from_ymd(2000, 2, 29, 0, 0, 0, 0, Scale::UTC).to_ymd();
let x = x.add_yr(1);
assert_eq!(x.day(), 28);Implementations§
Source§impl YmdHms
impl YmdHms
Sourcepub const fn add_yr(&self, n: i64) -> Self
pub const fn add_yr(&self, n: i64) -> Self
Adds (or subtracts) whole years, preserving month and day-of-month.
- Uses standard last-day-of-month clamping.
- Negative values subtract.
Sourcepub const fn add_mo(&self, n: i64) -> Self
pub const fn add_mo(&self, n: i64) -> Self
Adds (or subtracts) calendar months. Negative values subtract.
Sourcepub const fn add_wk(&self, n: i64) -> Self
pub const fn add_wk(&self, n: i64) -> Self
Adds (or subtracts) calendar weeks. Negative values subtract.
Sourcepub const fn add_days(&self, n: i64) -> Self
pub const fn add_days(&self, n: i64) -> Self
Adds (or subtracts) calendar days. Negative values subtract.
Sourcepub const fn add_attos(&self, n: i128) -> Self
pub const fn add_attos(&self, n: i128) -> Self
Adds (or subtracts) attoseconds. Negative values subtract.
Sourcepub const fn add_sec(&self, n: i64) -> Self
pub const fn add_sec(&self, n: i64) -> Self
Adds (or subtracts) whole seconds. Negative values subtract.
Sourcepub const fn add_min(&self, n: i64) -> Self
pub const fn add_min(&self, n: i64) -> Self
Adds (or subtracts) whole minutes. Negative values subtract.
Sourcepub const fn add_hr(&self, n: i64) -> Self
pub const fn add_hr(&self, n: i64) -> Self
Adds (or subtracts) whole hours. Negative values subtract.
Sourcepub const fn day(&self) -> u8
pub const fn day(&self) -> u8
Returns the day-of-month component (1–31, depending on month/year).
Sourcepub const fn sec(&self) -> u8
pub const fn sec(&self) -> u8
Returns the second component (0–60). The value 60 only occurs during
a positive leap second on Scale::UTC / UtcSpice / UtcHist.
Sourcepub const fn attos(&self) -> u64
pub const fn attos(&self) -> u64
Returns the attosecond (sub-second) component (0 ≤ attos < 10¹⁸).
Sourcepub const fn iso_yr(&self) -> i64
pub const fn iso_yr(&self) -> i64
Returns the ISO week year (can differ from the calendar year near January 1 / December 31).
Sourcepub const fn iso_wk(&self) -> u8
pub const fn iso_wk(&self) -> u8
Returns the ISO week number (1–53). Weeks start on Monday; week 1 is the week containing the first Thursday of the year.
Sourcepub const fn day_of_yr(&self) -> u16
pub const fn day_of_yr(&self) -> u16
Returns the day of the year (ordinal date), 1-based (Jan 1 = 1, Dec 31 = 365 or 366 in leap years).
Sourcepub const fn wkday(&self) -> u8
pub const fn wkday(&self) -> u8
Returns the weekday number according to Dt::jd_to_wkday
(typically 0 = Sunday … 6 = Saturday; exact convention is defined
by the Julian Day helper).
Sourcepub const fn wk_of_yr_sun(&self) -> u8
pub const fn wk_of_yr_sun(&self) -> u8
Returns the week of year number when weeks are considered to start on Sunday (US-style numbering).
Sourcepub const fn wk_of_yr_mon(&self) -> u8
pub const fn wk_of_yr_mon(&self) -> u8
Returns the week of year number when weeks are considered to start on Monday.
Source§impl YmdHms
impl YmdHms
Sourcepub fn add_yr_tz(&self, n: i64, tz: &str) -> Result<Self, DtErr>
pub fn add_yr_tz(&self, n: i64, tz: &str) -> Result<Self, DtErr>
Adds the given number of years in the specified IANA timezone, respecting timezone rules (including DST) and proper calendar arithmetic.
§Errors
- Jiff only supports years in the range
-9999..=9999. Years outside this range will return aDtErr. - If Jiff cannot find the timezone name or if applying the timezone would cause
the
jiff::Zonedto be outside the-9999..=9999year range then aDtErrwithDtErrKind::InvalidTimezoneOffsetis returned.
Sourcepub fn add_mo_tz(&self, n: i64, tz: &str) -> Result<Self, DtErr>
pub fn add_mo_tz(&self, n: i64, tz: &str) -> Result<Self, DtErr>
Adds the given number of months in the specified IANA timezone, respecting timezone rules and calendar month-end clamping.
§Errors
- Jiff only supports years in the range
-9999..=9999. Years outside this range will return aDtErr. - If Jiff cannot find the timezone name or if applying the timezone would cause
the
jiff::Zonedto be outside the-9999..=9999year range then aDtErrwithDtErrKind::InvalidTimezoneOffsetis returned.
Sourcepub fn add_wk_tz(&self, n: i64, tz: &str) -> Result<Self, DtErr>
pub fn add_wk_tz(&self, n: i64, tz: &str) -> Result<Self, DtErr>
Adds the given number of weeks in the specified IANA timezone.
§Errors
- Jiff only supports years in the range
-9999..=9999. Years outside this range will return aDtErr. - If Jiff cannot find the timezone name or if applying the timezone would cause
the
jiff::Zonedto be outside the-9999..=9999year range then aDtErrwithDtErrKind::InvalidTimezoneOffsetis returned.
Sourcepub fn add_days_tz(&self, n: i64, tz: &str) -> Result<Self, DtErr>
pub fn add_days_tz(&self, n: i64, tz: &str) -> Result<Self, DtErr>
Adds the given number of calendar days in the specified IANA timezone.
§Errors
- Jiff only supports years in the range
-9999..=9999. Years outside this range will return aDtErr. - If Jiff cannot find the timezone name or if applying the timezone would cause
the
jiff::Zonedto be outside the-9999..=9999year range then aDtErrwithDtErrKind::InvalidTimezoneOffsetis returned.
Sourcepub fn add_hr_tz(&self, n: i64, tz: &str) -> Result<Self, DtErr>
pub fn add_hr_tz(&self, n: i64, tz: &str) -> Result<Self, DtErr>
Adds the given number of hours in the specified IANA timezone, respecting timezone rules (including DST).
§Errors
- Jiff only supports years in the range
-9999..=9999. Years outside this range will return aDtErr. - If Jiff cannot find the timezone name or if applying the timezone would cause
the
jiff::Zonedto be outside the-9999..=9999year range then aDtErrwithDtErrKind::InvalidTimezoneOffsetis returned.
Sourcepub fn add_min_tz(&self, n: i64, tz: &str) -> Result<Self, DtErr>
pub fn add_min_tz(&self, n: i64, tz: &str) -> Result<Self, DtErr>
Adds the given number of minutes in the specified IANA timezone, respecting timezone rules (including DST).
§Errors
- Jiff only supports years in the range
-9999..=9999. Years outside this range will return aDtErr. - If Jiff cannot find the timezone name or if applying the timezone would cause
the
jiff::Zonedto be outside the-9999..=9999year range then aDtErrwithDtErrKind::InvalidTimezoneOffsetis returned.
Sourcepub fn add_sec_tz(&self, n: i64, tz: &str) -> Result<Self, DtErr>
pub fn add_sec_tz(&self, n: i64, tz: &str) -> Result<Self, DtErr>
Adds the given number of seconds in the specified IANA timezone.
§Errors
- Jiff only supports years in the range
-9999..=9999. Years outside this range will return aDtErr. - If Jiff cannot find the timezone name or if applying the timezone would cause
the
jiff::Zonedto be outside the-9999..=9999year range then aDtErrwithDtErrKind::InvalidTimezoneOffsetis returned.
Trait Implementations§
impl Copy for YmdHms
Source§impl<'de> Deserialize<'de> for YmdHms
impl<'de> Deserialize<'de> for YmdHms
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
impl Eq for YmdHms
impl StructuralPartialEq for YmdHms
Source§impl Tsify for YmdHms
impl Tsify for YmdHms
const DECL: &'static str = "/**\n * Combined Gregorian date + wall time with subsecond precision.\n * Has calendar aware and, when the `jiff-tz` feature is enabled,\n * timezone aware math functions.\n *\n * ## Examples\n *\n * **Creating a** [`YmdHms`].\n *\n * ```rust\n * use deep_time::{Dt, Scale};\n *\n * // clamped to 29\n * let x = Dt::from_ymd(2000, 2, 30, 0, 0, 0, 0, Scale::UTC).to_ymd();\n *\n * assert_eq!(x.day(), 29);\n * ```\n *\n * **Adding a year.** 2000 is a leap year and Feb. 29th is possible, but\n * 2001 isn\\\'t a leap year so the day is clamped to the 28th.\n *\n * ```rust\n * use deep_time::{Dt, Scale};\n *\n * let x = Dt::from_ymd(2000, 2, 29, 0, 0, 0, 0, Scale::UTC).to_ymd();\n * let x = x.add_yr(1);\n *\n * assert_eq!(x.day(), 28);\n * ```\n */\nexport interface YmdHms {\n yr: number;\n mo: number;\n day: number;\n hr: number;\n min: number;\n sec: number;\n attos: number;\n scale: Scale;\n}"
const SERIALIZATION_CONFIG: SerializationConfig
type JsType = JsType
fn into_js(&self) -> Result<Self::JsType, Error>where
Self: Serialize,
fn from_js<T>(js: T) -> Result<Self, Error>
Auto Trait Implementations§
impl Freeze for YmdHms
impl RefUnwindSafe for YmdHms
impl Send for YmdHms
impl Sync for YmdHms
impl Unpin for YmdHms
impl UnsafeUnpin for YmdHms
impl UnwindSafe for YmdHms
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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> DeserializeOwned for Twhere
T: for<'de> Deserialize<'de>,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key and return true if they are equal.