[tz] Buggy %z behaviour in strftime

Michael H Deckers michael.h.deckers at googlemail.com
Mon Jul 18 10:04:26 UTC 2022


On 2022-07-18 09:34, Almaz Mingaleev via tz wrote:
> Setting tm_gmtoff "fixes" it.



     According to page 366 in the newest C draft standard at
[https://www.open-std.org/jtc1/sc22/wg14/www/docs/n2912.pdf],
     strftime() looks at the member .tm_isdst for the format patterns
     %z and %Z; but this member was not initialized and is therefore
     "indeterminate", so that the result produced by strftime() may
     be "unspecified".

     By the way, the draft standard seems to be defective in that
     it does not state that strftime() also looks at the members
     .tm_year, .tm_mon, tm_mday, .tm_hour, .tm_min, .tm_sec
     for printing %z or %Z -- one cannot determine the offset
     or the time zone abbreviation without knowing the timestamp.

     Michael Deckers.




More information about the tz mailing list