From cea6aec610abcdc2c6ba480b5e7b8145fde200e3 Mon Sep 17 00:00:00 2001 From: Asger Hautop Drewsen Date: Thu, 12 Dec 2024 17:25:01 +0100 Subject: [PATCH] Add functions to DateTime to add milliseconds and Duration (#506) --- src/datetime.rs | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/src/datetime.rs b/src/datetime.rs index f52b16e9..f5c8e04e 100644 --- a/src/datetime.rs +++ b/src/datetime.rs @@ -363,6 +363,26 @@ impl crate::DateTime { self.0 } + /// Adds `millis` milliseconds to the [`DateTime`] saturating at [`DateTime::MIN`] and + /// [`DateTime::MAX`]. + pub const fn saturating_add_millis(self, millis: i64) -> Self { + Self::from_millis(self.0.saturating_add(millis)) + } + + /// Adds `duration` to the [`DateTime`] saturating at [`DateTime::MAX`]. + /// + /// As [`DateTime`] only have millisecond-precision this will only use the whole milliseconds + /// of `duration`. + pub const fn saturating_add_duration(self, duration: Duration) -> Self { + // i64::try_from isn't const + let millis = duration.as_millis(); + if millis > i64::MAX as u128 { + Self::from_millis(i64::MAX) + } else { + self.saturating_add_millis(millis as i64) + } + } + #[deprecated(since = "2.3.0", note = "Use try_to_rfc3339_string instead.")] /// Convert this [`DateTime`] to an RFC 3339 formatted string. Panics if it could not be /// represented in that format.