Here is first time 1:30 AM happened on the morning of Daylight Saving Time ending in 2019 in Chicago:
bash$ TZ=posix/America/Chicago date --date=@1572762600
Sun Nov 3 01:30:00 CDT 2019
bash$ TZ=posix/America/Chicago date --date=@1572762600 --iso=minute
2019-11-03T01:30-05:00
After "fall back", here is the second time 1:30 AM happened, one hour later (confusingly a permutation of the digits of Unix time):
bash$ TZ=posix/America/Chicago date --date=@1572766200
Sun Nov 3 01:30:00 CST 2019
bash$ TZ=posix/America/Chicago date --date=@1572766200 --iso=minute
2019-11-03T01:30-06:00
If we omit the timezone suffix (e.g., -05:00 or -06:00), the parser chooses the first 1:30. Why?
bash$ TZ=posix/America/Chicago date --debug --date=2019-11-03T01:30
date: parsed datetime part: (Y-M-D) 2019-11-03 01:30:00
date: input timezone: TZ="posix/America/Chicago" environment value
date: using specified time as starting value: '01:30:00'
date: starting date/time: '(Y-M-D) 2019-11-03 01:30:00'
date: '(Y-M-D) 2019-11-03 01:30:00' = 1572762600 epoch-seconds
date: timezone: TZ="posix/America/Chicago" environment value
date: final: 1572762600.000000000 (epoch-seconds)
date: final: (Y-M-D) 2019-11-03 06:30:00 (UTC)
date: final: (Y-M-D) 2019-11-03 01:30:00 (UTC-05)
Sun Nov 3 01:30:00 CDT 2019
Perhaps it should warn if the time is ambiguous. But determining whether a given time is ambiguous seems difficult.
No comments:
Post a Comment