[tz] [PROPOSED] zic option for including data from a certain year onward
Christopher Wong
christopher.wong at axis.com
Fri Mar 15 17:44:51 UTC 2019
Hi Paul,
Regarding the range 1977-1984. Sorry, I thought the start range was 1877, so you are absolutely right that the transition is correct. Hope I didn't make you double check this for too long.
Thanks for adding this feature and fixing related bugs so quickly!
BR,
Christopher Wong
________________________________________
From: Paul Eggert <eggert at cs.ucla.edu>
Sent: Friday, March 15, 2019 17:45
To: Christopher Wong
Cc: Scott Nelson; Time Zone Mailing List
Subject: Re: [tz] [PROPOSED] zic option for including data from a certain year onward
On 3/14/19 7:13 PM, Christopher Wong wrote:
> I rebased to the latest and did some testing. I didn't got any more segmentation fault, so that is fixed.
>
> However, I encountered something else related to the truncation. I compiled with the following range 1977-1984 :
>
> ./zic -L /dev/null -d $ZONEINFO -r @220924800/@441763200 ${tz}
>
> ./zdump -v $ZONEINFO/Australia/Perth
>
> The result I got was:
>
> /home/christwo/dists/tz/test_zic_github/Australia/Perth -9223372036854775808 = NULL
> /home/christwo/dists/tz/test_zic_github/Australia/Perth -9223372036854689408 = NULL
> /home/christwo/dists/tz/test_zic_github/Australia/Perth Sat Oct 29 17:59:59 1983 UT = Sun Oct 30 01:59:59 1983 AWST isdst=0 gmtoff=28800
> /home/christwo/dists/tz/test_zic_github/Australia/Perth Sat Oct 29 18:00:00 1983 UT = Sun Oct 30 03:00:00 1983 AWDT isdst=1 gmtoff=32400
> /home/christwo/dists/tz/test_zic_github/Australia/Perth 9223372036854689407 = NULL
> /home/christwo/dists/tz/test_zic_github/Australia/Perth 9223372036854775807 = NULL
>
> I was expecting many dates before 1983.
But the range you specified (@220924800/@441763200) is from 1977-01-01
00:00 UTC through 1984-01-01 00:00 UTC. Perth saw only one transition
during that period, namely, the 1983-10-29 transition listed above. So
this zdump output is correct, no?
zdump by design does not output no-op transitions like the transitions
at 220924800 and at 441763200 in that TZif file.
> I extracted the timestamps below, should the last transition be 1s after range end?
>
> 0d 2b 0b 80 220924800 Saturday, January 1, 1977 0:00:00
> 1a 01 62 a0 436298400 Saturday, October 29, 1983 18:00:00
> 1a 54 c5 81 441763201 Sunday, January 1, 1984 0:00:01
This was due to an off-by-one discrepancy between the zic -r syntax and
the RFC 8536 truncation rules. 'zic -r /@T' meant to truncate *after*
time T, whereas RFC 8536 means to truncate *before* time T (this is as
per RFC 7808 section 3.9). Thanks for pointing out this off-by-one
discrepancy. It's better for zic to be consistent with the RFCs, so I
installed the attached patch to remove the discrepancy, and also to
check more carefully for overflow and for empty ranges.
More information about the tz
mailing list