From d2d3ae59ab315ee90327cef144db9c19c1742d68 Mon Sep 17 00:00:00 2001 From: Serhiy Barhamon Date: Sat, 14 Oct 2023 12:28:09 +0200 Subject: [PATCH] consider timestamp without colon in offset as wrong date refactor when https://github.com/chronotope/chrono/pull/1083 will land --- src/nodes/metadata.rs | 19 ++++++++++++++----- 1 file changed, 14 insertions(+), 5 deletions(-) diff --git a/src/nodes/metadata.rs b/src/nodes/metadata.rs index 2bc90b4..6b92785 100644 --- a/src/nodes/metadata.rs +++ b/src/nodes/metadata.rs @@ -97,11 +97,16 @@ impl Deserializer for Metadata { if line.starts_with("header: ") { meta.header = Some(line.replace("header: ", "")); } else if line.starts_with("timestamp: ") { - meta.timestamp = DateTime::parse_from_str( - line.replace("timestamp: ", "").as_str(), - "%Y-%m-%d %H:%M:%S %z", - ) - .ok(); + // remove this when %:z works as expected + if line.trim().chars().rev().nth(5) == Some('+') { + meta.timestamp = DateTime::parse_from_str( + line.replace("timestamp: ", "").as_str(), + // %:z does not work as expected + // https://github.com/chronotope/chrono/pull/1083 + "%Y-%m-%d %H:%M:%S %:z", + ) + .ok(); + } } else if line.starts_with("image: ") { meta.image = Some(line.replace("image: ", "")); } else if line.starts_with("preview: ") { @@ -213,6 +218,10 @@ mod tests { #[test] fn deserialize_wrong_date() { + assert_eq!( + Metadata::deserialize("timestamp: 2022-01-01 00:00:00 +0200\n^^^\n\n"), + Some(Metadata::new::<&str>(None, None, None, None, None)) + ); assert_eq!( Metadata::deserialize("timestamp: 2022-01-01 00:00:00\n^^^\n\n"), Some(Metadata::new::<&str>(None, None, None, None, None))