X-Authentication-Warning: delorie.com: mail set sender to djgpp-workers-bounces using -f X-Recipient: djgpp-workers AT delorie DOT com Date: Sat, 27 Jul 2013 11:33:56 +0300 From: Eli Zaretskii <eliz AT gnu DOT org> Subject: Re: zoneinfo not able to recognize if daylight saving time is in effect. In-reply-to: <51F2F068.2040504@gmx.de> X-012-Sender: halo1 AT inter DOT net DOT il To: djgpp-workers AT delorie DOT com Message-id: <83fvv0z9jf.fsf@gnu.org> References: <51F2C9B5 DOT 3090202 AT gmx DOT de> <83li4tyvcx DOT fsf AT gnu DOT org> <83iozxyuzm DOT fsf AT gnu DOT org> <51F2F068 DOT 2040504 AT gmx DOT de> Reply-To: djgpp-workers AT delorie DOT com Errors-To: nobody AT delorie DOT com X-Mailing-List: djgpp-workers AT delorie DOT com X-Unsubscribes-To: listserv AT delorie DOT com Precedence: bulk > Date: Fri, 26 Jul 2013 23:55:52 +0200 > From: Juan Manuel Guerrero <juan DOT guerrero AT gmx DOT de> > > > The 2 failures in 2.03 are because US timezone rules were changed in > > 2007, and 2.03 doesn't have those new rules in its timezone database. > > The failures are precisely in March and November, which were affected > > by the change. Import the latest timezone database, and the problem > >should go away. > > I am aware of this. The user told me about this. Then what exactly is the issue we are discussing? If the zoneinfo database is outdated, one should expect failures here and there. I mean, it would be nice to have all the information that you have, including what you know and don't know, and what are the issues where you are seeking help, be spelled out, so that we could concentrate on them, instead of exploring things you already did and understood. > > As for 2.04, I don't know which timezone database it uses. Did > > someone bother to update from upstream? > > I do not know what timezone database is used by 2.04, but I have updated > the repository code with tzcode2012j.tar.gz and tzdata2012j.tar.gz. > See http://www.delorie.com/archives/browse.cgi?p=djgpp-workers/2012/12/04/13:10:10 > and later. I downloaded the archives from ftp://ftp.iana.org/tz/. Have I > missed to download something more? According to what I have read there > everything what is required are the matching code and data archives and > nothing more. Or am I missing something? I don't think you miss something, assuming that, after downloading the tz files, you re-generated to zoneinfo files DJGPP uses, in the zoneinfo/ directory, and that nothing went wrong during that generation. > > > Anyway, the test program works for me, with the original djdev203 > > > timezone files. > > > > I meant the only un-ifdef'ed away test works. Of the others, 2 fail. > > I have intentionally focused on this single line. I will base all analysis only > on this particular code line (time value). > > 1) If I run the test code using my stock 2.03 installation that uses > djtzn203.zip (time stamp of the dsm file is 2000-04-13) I get: > > time_t 1372780800 expected 2013-07-02 12:00:00 EDT > got 2013-07-02 12:00:00 EDT > Test passed > > It is well known that the timezone database is outdated. > Why is the "correct" result produced? > Fortunate coincidence? It passes because July was in EDT back when we updated the zoneinfo files, and still is today. All that the zoneinfo files tell is what is the offset from UTC during standard time, what is the offset during the daylight savings time, and what are the rules to decide when to switch between the standard and daylight savings time. The offsets didn't change for New York since 2.03 was released (and probably never will, not in our lifetime), but the switch rules did change in 2007. However, these rules only affect the dates around March-April and October-November, which is when the switch happens. Before 2007, the switch happened on a fixed date, after 2007 there are more complex rules like "2nd Sunday of March". That is why you get failures around March and November, but not in July. > 3) If I run the test code using my repository installation that uses > the database from tzdata2012j.tar.gz I get: > > time_t 1372780800 expected 2013-07-02 12:00:00 EDT > got 2013-07-02 11:00:00 EST FAIL > Test FAILED > > Although the database has been updated, now the result is certainly wrong. The obvious conclusion is that the new database is somehow wrong. tzdata2012j.tar.gz has these rules in 'northamerica' file: Rule US 2007 max - Mar Sun>=8 2:00 1:00 D Rule US 2007 max - Nov Sun>=1 2:00 0 S # Zone NAME GMTOFF RULES FORMAT [UNTIL] Zone America/New_York -4:56:02 - LMT 1883 Nov 18 12:03:58 -5:00 US E%sT 1920 -5:00 NYC E%sT 1942 -5:00 US E%sT 1946 -5:00 NYC E%sT 1967 -5:00 US E%sT This should cause America/New_York use the "US" rules from 1967 on, and in particular, the above two "US" rules since 2007. If that doesn't happen, maybe something went wrong when this was translated to the zoneinfo files? I vaguely remember that the tzcode sources needed changes to produce correct results, something with byte reversal, perhaps? I suggest to make sure those changes are propagated to v2.04 and to the programs you used to generate the zoneinfo DB. Here are the mails that probably was the origin of my vague memory: http://www.delorie.com/djgpp/mail-archives/browse.cgi?p=djgpp/2000/04/20/13:29:28 http://www.delorie.com/djgpp/mail-archives/browse.cgi?p=djgpp/2000/04/11/16:50:20 Since those mail threads are related to cross-compiled DJGPP, those problems are probably not relevant to this one, as long as we are talking about zoneinfo files produced natively on DOS/Windows using DJGPP. If worse comes to worst, yes, you will have to step through the code that reads the DST rules and see what's wrong there.