summaryrefslogtreecommitdiff
path: root/time.c
diff options
context:
space:
mode:
authornagachika <nagachika@ruby-lang.org>2022-09-25 12:38:51 +0900
committernagachika <nagachika@ruby-lang.org>2022-09-25 12:38:51 +0900
commit13ee4b2c35bad0f893d5ed5a6fdca62da406f958 (patch)
tree30ae4e5488be21c7a4a46c6ea8ec6e77b2c75254 /time.c
parent720de2008ca06edb22e5ad7d1432fee4f2575e00 (diff)
merge revision(s) 68903df6f6fc548f3bf68fb09ee8b2495dcd28f0: [Backport #18922]
[Bug #18922] Normalize time at 24:00:00 UTC --- test/ruby/test_time.rb | 2 ++ time.c | 14 ++++++++++++++ 2 files changed, 16 insertions(+)
Diffstat (limited to 'time.c')
-rw-r--r--time.c14
1 files changed, 14 insertions, 0 deletions
diff --git a/time.c b/time.c
index 77f42fc89a..992e5403d0 100644
--- a/time.c
+++ b/time.c
@@ -654,6 +654,7 @@ static uint32_t month_arg(VALUE arg);
static VALUE validate_utc_offset(VALUE utc_offset);
static VALUE validate_zone_name(VALUE zone_name);
static void validate_vtm(struct vtm *vtm);
+static void vtm_add_day(struct vtm *vtm, int day);
static uint32_t obj2subsecx(VALUE obj, VALUE *subsecx);
static VALUE time_gmtime(VALUE);
@@ -2025,6 +2026,12 @@ vtm_add_offset(struct vtm *vtm, VALUE off, int sign)
vtm->hour = hour;
}
+ vtm_add_day(vtm, day);
+}
+
+static void
+vtm_add_day(struct vtm *vtm, int day)
+{
if (day) {
if (day < 0) {
if (vtm->mon == 1 && vtm->mday == 1) {
@@ -2386,6 +2393,13 @@ time_init_args(rb_execution_context_t *ec, VALUE time, VALUE year, VALUE mon, VA
if (utc == UTC_ZONE) {
tobj->timew = timegmw(&vtm);
+ if (vtm.hour == 24) { /* special case: 24:00:00 only */
+ /* Since no need to take care of DST in UTC, just reset
+ * hour and advance date, not to discard the validated
+ * vtm. */
+ vtm.hour = 0;
+ vtm_add_day(&vtm, 1);
+ }
tobj->vtm = vtm;
tobj->tm_got = 1;
TZMODE_SET_UTC(tobj);