From c3f8b271333252a7b6ce7545d7dd685f0229ab1f Mon Sep 17 00:00:00 2001 From: Dar Dahlen Date: Mon, 8 Jul 2024 10:12:01 -0700 Subject: [PATCH] Division for negative number was rounding up This is normal behavior for negative numbers on CPUs, but unexpected behavior for math. This required changing the divisions to `div_euclid` to match the expected behavior. --- src/neospy_core/src/time/mod.rs | 19 ++++++++++++------- 1 file changed, 12 insertions(+), 7 deletions(-) diff --git a/src/neospy_core/src/time/mod.rs b/src/neospy_core/src/time/mod.rs index b81cdca..b6ecdfe 100644 --- a/src/neospy_core/src/time/mod.rs +++ b/src/neospy_core/src/time/mod.rs @@ -123,13 +123,13 @@ impl Time { let mut l = offset.div_euclid(1.0) as i64 + 68569; - let n = (4 * l) / 146097; - l -= (146097 * n + 3) / 4; - let i = (4000 * (l + 1)) / 1461001; - l -= (1461 * i) / 4 - 31; - let k = (80 * l) / 2447; - let day = l - (2447 * k) / 80; - l = k / 11; + let n = (4 * l).div_euclid(146097); + l -= (146097 * n + 3).div_euclid(4); + let i = (4000 * (l + 1)).div_euclid(1461001); + l -= (1461 * i).div_euclid(4) - 31; + let k = (80 * l).div_euclid(2447); + let day = l - (2447 * k).div_euclid(80); + l = k.div_euclid(11); let month = k + 2 - 12 * l; let year = 100 * (n - 49) + i + l; @@ -223,6 +223,11 @@ mod tests { let t2 = Time::::from_year_month_day(763, 9, 18, 0.5); assert!(t2.jd == 2000000.); + + let ymd = Time::::new(-68774.4991992591).year_month_day(); + assert!(ymd.0 == -4901); + assert!(ymd.1 == 8); + assert!(ymd.2 == 8); } #[test]