From cf103266b3b63b8b36908d1457a981b3ab1acab8 Mon Sep 17 00:00:00 2001 From: Dominik Csapak Date: Fri, 4 Sep 2020 14:33:31 +0200 Subject: [PATCH] tools/systemd/tm_editor: move conversion of the year into getter and setter the tm struct contains the year - 1900 but we added that if we want to use the libc normalization correctly, the tm struct must have the correct year in it, else the computations for timezones, etc. fail instead add a getter that adds the years and a setter that subtracts it again Signed-off-by: Dominik Csapak --- src/tools/systemd/tm_editor.rs | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/src/tools/systemd/tm_editor.rs b/src/tools/systemd/tm_editor.rs index b098f1cb..677e0520 100644 --- a/src/tools/systemd/tm_editor.rs +++ b/src/tools/systemd/tm_editor.rs @@ -10,13 +10,11 @@ pub struct TmEditor { impl TmEditor { pub fn new(epoch: i64, utc: bool) -> Result { - let mut t = if utc { gmtime(epoch)? } else { localtime(epoch)? }; - t.tm_year += 1900; // real years for clarity + let t = if utc { gmtime(epoch)? } else { localtime(epoch)? }; Ok(Self { utc, t }) } pub fn into_epoch(mut self) -> Result { - self.t.tm_year -= 1900; let epoch = if self.utc { timegm(&mut self.t)? } else { timelocal(&mut self.t)? }; Ok(epoch) } @@ -31,6 +29,7 @@ impl TmEditor { self.normalize_time() } + pub fn year(&self) -> libc::c_int { self.t.tm_year + 1900 } // see man mktime pub fn hour(&self) -> libc::c_int { self.t.tm_hour } pub fn min(&self) -> libc::c_int { self.t.tm_min } pub fn sec(&self) -> libc::c_int { self.t.tm_sec } @@ -89,7 +88,7 @@ impl TmEditor { } pub fn set_year(&mut self, v: libc::c_int) -> Result<(), Error> { - self.t.tm_year = v; + self.t.tm_year = v - 1900; self.normalize_time() } }