mirror of
https://github.com/ruby/ruby.git
synced 2025-08-15 13:39:04 +02:00
merge revision(s) d6a2bce64a7fa1099e507e1d36b5f1533f42f60f,c687be4bc01c9ce52ea990945d9304d6fe59fe9b: [Backport #16159]
time.c (find_time_t): fix round-to-zero bug `find_time_t` did not work correctly for year older than the Epoch because it used C's integer division (which rounds negative to zero). For example, `TIme.new(1933)` returned a wrong time whose year is 1922 in Asia/Kuala_Lumpur because there is no 00:00:00 1st Jan. 1933 in the time zone. ``` $ TZ=Asia/Kuala_Lumpur ruby -e 'p Time.new(1933)' 1932-12-31 00:00:00 +0700 ``` This change fixes the issue by using `DIV` macro instead of `/`. Now `Time.new(1933)` returns a time in 1933. ``` $ TZ=Asia/Kuala_Lumpur ruby -e 'p Time.new(1933)' 1933-01-01 00:20:00 +0720 ``` [Bug #16159] Added a test for [Bug #16159] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_5@67864 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
ac6dd2fecc
commit
b4446de7ad
3 changed files with 13 additions and 7 deletions
|
@ -155,6 +155,12 @@ class TestTimeTZ < Test::Unit::TestCase
|
|||
}
|
||||
end
|
||||
|
||||
def test_asia_kuala_lumpur
|
||||
with_tz(tz="Asia/Kuala_Lumpur") {
|
||||
assert_time_constructor(tz, "1933-01-01 00:20:00 +0720", :local, [1933])
|
||||
}
|
||||
end
|
||||
|
||||
def test_canada_newfoundland
|
||||
with_tz(tz="America/St_Johns") {
|
||||
assert_time_constructor(tz, "2007-11-03 23:00:59 -0230", :new, [2007,11,3,23,0,59,:dst])
|
||||
|
|
12
time.c
12
time.c
|
@ -2958,12 +2958,12 @@ find_time_t(struct tm *tptr, int utc_p, time_t *tp)
|
|||
|
||||
*tp = guess_lo +
|
||||
((tptr->tm_year - tm_lo.tm_year) * 365 +
|
||||
((tptr->tm_year-69)/4) -
|
||||
((tptr->tm_year-1)/100) +
|
||||
((tptr->tm_year+299)/400) -
|
||||
((tm_lo.tm_year-69)/4) +
|
||||
((tm_lo.tm_year-1)/100) -
|
||||
((tm_lo.tm_year+299)/400) +
|
||||
DIV((tptr->tm_year-69), 4) -
|
||||
DIV((tptr->tm_year-1), 100) +
|
||||
DIV((tptr->tm_year+299), 400) -
|
||||
DIV((tm_lo.tm_year-69), 4) +
|
||||
DIV((tm_lo.tm_year-1), 100) -
|
||||
DIV((tm_lo.tm_year+299), 400) +
|
||||
tptr_tm_yday -
|
||||
tm_lo.tm_yday) * 86400 +
|
||||
(tptr->tm_hour - tm_lo.tm_hour) * 3600 +
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
#define RUBY_VERSION "2.5.8"
|
||||
#define RUBY_RELEASE_DATE "2020-03-31"
|
||||
#define RUBY_PATCHLEVEL 213
|
||||
#define RUBY_PATCHLEVEL 214
|
||||
|
||||
#define RUBY_RELEASE_YEAR 2020
|
||||
#define RUBY_RELEASE_MONTH 3
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue