-C Attempt\sto\sfix\sdate/time\scalculations\sfor\sdays\searlier\sthan\s0400-03-01.\nSee\s[forum:/forumpost/eaa0a09786c6368b|forum\sthread\seaa0a09786c6368b].
-D 2024-08-19T12:54:12.528
+C New\sdate/time\stest\scases\sto\svalidate\sancient\sdates.
+D 2024-08-19T13:53:49.904
F .fossil-settings/empty-dirs dbb81e8fc0401ac46a1491ab34a7f2c7c0452f2f06b54ebb845d024ca8283ef1
F .fossil-settings/ignore-glob 35175cdfcf539b2318cb04a9901442804be81cd677d8b889fcc9149c21f239ea
F LICENSE.md df5091916dbb40e6e9686186587125e1b2ff51f022cc334e886c19a0e9982724
F test/date2.test 7e12ec14aaf4d5e6294b4ba140445b0eca06ea50062a9c3a69c4ee13d0b6f8b1
F test/date3.test a1b77abf05c6772fe5ca2337cac1398892f2a41e62bce7e6be0f4a08a0e64ae5
F test/date4.test 75dc8401e8c0639a228cd26a6eaa4ff5ea8ccda912b9853d1c9462c476670e17
+F test/date5.test 14ba189bc4d03efc371dd5302e035764f6633355a3e13acb4a45e7b33530231e
F test/dbdata.test 042f49acff3438f940eeba5868d3af080ae64ddf26ae78f80c92bec3ca7d8603
F test/dbfuzz.c 73047c920d6210e5912c87cdffd9a1c281d4252e
F test/dbfuzz001.test 6c9a4622029d69dc38926f115864b055cb2f39badd25ec22cbfb130c8ba8e9c3
F vsixtest/vsixtest.vcxproj.data 2ed517e100c66dc455b492e1a33350c1b20fbcdc
F vsixtest/vsixtest.vcxproj.filters 37e51ffedcdb064aad6ff33b6148725226cd608e
F vsixtest/vsixtest_TemporaryKey.pfx e5b1b036facdb453873e7084e1cae9102ccc67a0
-P 8d170e07e20c21a5bb97fdc8c2d01d92178f5fe740e60d203e4621747cfce33e
-R 63b5eb42616efb9e489a03771c227de0
-T *branch * ancient-date-fix
-T *sym-ancient-date-fix *
-T -sym-trunk *
+P 00cae11fffaf50e2133915e851d41098d00b6b1458e1438bcb6664e1411d8498
+R 020e143aeb047149147ee2aa5a7ba85f
U drh
-Z baa6c6f17edc1a9ecec4f4cec4c126b5
+Z d05bb26a1492de783006f86a1565084e
# Remove this line to create a well-formed Fossil manifest.
--- /dev/null
+# 2024-08-19
+#
+# The author disclaims copyright to this source code. In place of
+# a legal notice, here is a blessing:
+#
+# May you do good and not evil.
+# May you find forgiveness for yourself and forgive others.
+# May you share freely, never taking more than you give.
+#
+#***********************************************************************
+#
+# https://sqlite.org/forum/forumpost/eaa0a09786c6368b
+#
+# Apparently SQLite has been miscomputing leap-year dates before
+# the year 0400.
+#
+
+set testdir [file dirname $argv0]
+source $testdir/tester.tcl
+
+# Skip this whole file if date and time functions are omitted
+# at compile-time
+#
+ifcapable {!datetime} {
+ finish_test
+ return
+}
+
+# Data sources:
+# 1-10 https://ssd.jpl.nasa.gov/tools/jdc/#/cd
+# 11 Jean Meeus, Astronomical Algorithms, ISBN 0-943396-61-1, p.59
+# 12 https://en.wikipedia.org/wiki/Julian_day
+#
+# ID YEAR MONTH DAY JD
+set date5data {
+ 1 2024 2 29 2460369.5
+ 2 2024 3 1 2460370.5
+ 3 2023 2 28 2460003.5
+ 4 2023 3 1 2460004.5
+ 5 2000 2 29 2451603.5
+ 6 2000 3 1 2451604.5
+ 7 1900 2 28 2415078.5
+ 8 1900 3 1 2415079.5
+ 9 1712 2 29 2346413.5
+ 10 1712 3 1 2346414.5
+ 11 1977 4 26 2443259.5
+ 12 2013 1 1 2456293.5
+}
+
+foreach {id y m d jd} $date5data {
+ set date [format %04d-%02d-%02d $y $m $d]
+ do_execsql_test date5-jd$jd {
+ SELECT date($::jd);
+ } $date
+ do_execsql_test date5-cal/$date {
+ SELECT julianday($::date);
+ } $jd
+ for {set i 1} {$y+400*$i<=9999} {incr i} {
+ set y2 [expr {$y+400*$i}]
+ set date2 [format %04d-%02d-%02d $y2 $m $d]
+ set jd2 [expr {$jd+146097*$i}]
+ do_execsql_test date5-jd$jd2 {
+ SELECT date($::jd2);
+ } $date2
+ do_execsql_test date5-cal/$date2 {
+ SELECT julianday($::date2);
+ } $jd2
+ }
+ for {set i 1} {$y-400*$i>=-4712} {incr i} {
+ set y2 [expr {$y-400*$i}]
+ if {$y2<0} {
+ set date2 [format -%04d-%02d-%02d [expr {-$y2}] $m $d]
+ } else {
+ set date2 [format %04d-%02d-%02d $y2 $m $d]
+ }
+ set jd2 [expr {$jd-146097*$i}]
+ do_execsql_test date5-jd$jd2 {
+ SELECT date($::jd2);
+ } $date2
+ do_execsql_test date5-cal/$date2 {
+ SELECT julianday($::date2);
+ } $jd2
+ }
+}
+
+finish_test