Merge pull request #37 from dcurrie/issue-#34
Fix parsetime to initialize timezone, issue #34.
This commit is contained in:
commit
4087d6af96
|
@ -82,7 +82,7 @@ void timestring(double seconds, char *buffer, size_t len)
|
|||
{
|
||||
time_t tme = (time_t)seconds;
|
||||
|
||||
#ifdef LINUX
|
||||
#if defined(LINUX) || defined(MACOSX) || defined(OPENBSD) || defined(FREEBSD)
|
||||
char *fmt = "%c"; /* needed to suppress GCC warning */
|
||||
struct tm tm;
|
||||
|
||||
|
@ -117,6 +117,8 @@ double parsetime(const char *str)
|
|||
|
||||
res = strptime(str, fmt, &tm);
|
||||
if (res != NULL) {
|
||||
tm.tm_isdst = -1; /* Not set by strptime(); tells mktime() to determine
|
||||
whether daylight saving time is in effect */
|
||||
t = mktime(&tm);
|
||||
if (t == ((time_t)-1))
|
||||
return -1;
|
||||
|
|
|
@ -283,5 +283,9 @@
|
|||
(assert (not (equal? (hash (iota 41))
|
||||
(hash (iota 42)))))
|
||||
|
||||
(if (top-level-bound? 'time.fromstring)
|
||||
(assert (let ((ts (time.string (time.now))))
|
||||
(eqv? ts (time.string (time.fromstring ts))))))
|
||||
|
||||
(princ "all tests pass\n")
|
||||
#t
|
||||
|
|
Loading…
Reference in New Issue