[tz] Direct implementation of mktime_z

Ted Phelps phelps at pobox.com
Sat Sep 24 07:50:49 UTC 2022


Hi Guy,

On 24/9/22 17:27, Guy Harris wrote:
> This appears to be more of "faster implementation of mtkime()" than "direct implementation of mtkime_z()", as the bulk of what you're talking about appears to be a faster way of converting a struct tm into a time_t rather than adding support for having a routine that can convert a struct tm, in an *arbitrary* tzdb region rather has the current tzdb region, to a time_t.  The two are independent - the "convert a struct tm, representing local time in a given tzdb region, to a time_t" part is orthogonal to the "is the given tzdb region the default region for the process, or is it an arbitrary region specified by a handle?"

That's right, I'm talking about a faster way to convert a struct tm to a 
time_t.  Perhaps "direct" was a poor choice of word; I was trying to 
distinguish between the "binary search the time_t range" approach, which 
is arguably an indirect way to perform the calculation, to an approach 
where the time_t is calculated with a bunch of algebra and whatnot.  I 
can see how my mention of mktime_z could be interpreted to mean what you 
say.  Apologies for the sloppy subject.

> For the latter, one issue si "what's the appropriate time zone name abbreviation for that particular time, and, if there's a way to 'close' a handle for a tzdb region, then, if there's a call that provides a string for that abbreviation, does that string survive closing the handle for the region?"

Indeed, the fact that tm_zone is a pointer is a frustrating part of 
struct tm, but it's not one I'm attempting to address.

-Ted




More information about the tz mailing list