2 * time support routines that are easier to do in C than in Lisp
6 * This software is part of the SBCL system. See the README file for
9 * This software is derived from the CMU CL system, which was
10 * written at Carnegie Mellon University and released into the
11 * public domain. The software is in the public domain and is
12 * provided with absolutely no warranty. See the COPYING and CREDITS
13 * files for more information.
21 #ifdef LISP_FEATURE_HPUX
22 struct tm *gmtime_r(const time_t *timer, struct tm *result);
23 struct tm *localtime_r(const time_t *timer, struct tm *result);
26 void get_timezone(time_t when, int *secwest, boolean *dst)
31 #ifdef LISP_FEATURE_WIN32
32 /* No _r versions on Windows, but the API documentation also
33 * doesn't warn them about being non-reentrant... So here's
34 * hoping they actually are -- once Windows grows threads
35 * this better be checked, though.
37 * The Windows versions also don't support times before the
38 * epoch, so we kludge it. */
41 ltm = *localtime(&when);
44 ltm = *localtime_r(&when, <m);
45 gtm = *gmtime_r(&when, >m);
48 sw = (((gtm.tm_hour*60)+gtm.tm_min)*60+gtm.tm_sec) - (((ltm.tm_hour*60)+ltm.tm_min)*60+ltm.tm_sec);
49 if ((gtm.tm_wday + 1) % 7 == ltm.tm_wday)
51 else if (gtm.tm_wday == (ltm.tm_wday + 1) % 7)