Clean up time handling; always assume we have tzset().
[mmh] / sbr / dtime.c
index b427dfd..e0405e9 100644 (file)
@@ -9,23 +9,9 @@
 #include <h/mh.h>   /* for snprintf() */
 #include <h/nmh.h>
 #include <h/tws.h>
+#include <time.h>
 
-#if !defined(HAVE_STRUCT_TM_TM_GMTOFF) && !defined(HAVE_TZSET)
-# include <sys/timeb.h>
-#endif
-
-#ifdef TIME_WITH_SYS_TIME
-# include <sys/time.h>
-# include <time.h>
-#else
-# ifdef HAVE_SYS_TIME_H
-# include <sys/time.h>
-# else
-#  include <time.h>
-# endif
-#endif
-
-#if !defined(HAVE_STRUCT_TM_TM_GMTOFF) && defined(HAVE_TZSET)
+#if !defined(HAVE_STRUCT_TM_TM_GMTOFF)
 extern int daylight;
 extern long timezone;
 extern char *tzname[];
@@ -66,46 +52,6 @@ struct zone {
        int shift;
 };
 
-static struct zone zones[] = {
-       { "GMT", "BST", 0 },
-       { "EST", "EDT", -5 },
-       { "CST", "CDT", -6 },
-       { "MST", "MDT", -7 },
-       { "PST", "PDT", -8 },
-#if 0
-/* RFC1123 specifies do not use military TZs */
-       { "A", NULL, -1 },
-       { "B", NULL, -2 },
-       { "C", NULL, -3 },
-       { "D", NULL, -4 },
-       { "E", NULL, -5 },
-       { "F", NULL, -6 },
-       { "G", NULL, -7 },
-       { "H", NULL, -8 },
-       { "I", NULL, -9 },
-       { "K", NULL, -10 },
-       { "L", NULL, -11 },
-       { "M", NULL, -12 },
-       { "N", NULL, 1 },
-#ifndef HUJI
-       { "O", NULL, 2 },
-#else
-       { "JST", "JDT", 2 },
-#endif
-       { "P", NULL, 3 },
-       { "Q", NULL, 4 },
-       { "R", NULL, 5 },
-       { "S", NULL, 6 },
-       { "T", NULL, 7 },
-       { "U", NULL, 8 },
-       { "V", NULL, 9 },
-       { "W", NULL, 10 },
-       { "X", NULL, 11 },
-       { "Y", NULL, 12 },
-#endif
-       { NULL, NULL, 0 }
-};
-
 static int dmsize[] = {
        31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31
 };
@@ -139,7 +85,7 @@ dlocaltime(time_t *clock)
        static struct tws tw;
        struct tm *tm;
 
-#if !defined(HAVE_STRUCT_TM_TM_GMTOFF) && !defined(HAVE_TZSET)
+#if !defined(HAVE_STRUCT_TM_TM_GMTOFF)
        struct timeb tb;
 #endif
 
@@ -171,13 +117,8 @@ dlocaltime(time_t *clock)
        if (tm->tm_isdst)  /* if DST is in effect */
                tw.tw_zone -= 60;  /* reset to normal offset */
 #else
-# ifdef HAVE_TZSET
        tzset();
        tw.tw_zone = -(timezone / 60);
-# else
-       ftime(&tb);
-       tw.tw_zone = -tb.timezone;
-# endif
 #endif
 
        tw.tw_flags &= ~TW_SDAY;
@@ -355,7 +296,6 @@ char *
 dtimezone(int offset, int flags)
 {
        int hours, mins;
-       struct zone *z;
        static char buffer[10];
 
        if (offset < 0) {
@@ -367,14 +307,8 @@ dtimezone(int offset, int flags)
        }
 
        if (!(flags & TW_ZONE) && mins == 0) {
-#if defined(HAVE_TZSET) && defined(HAVE_TZNAME)
                tzset();
                return ((flags & TW_DST) ? tzname[1] : tzname[0]);
-#else
-               for (z = zones; z->std; z++)
-                       if (z->shift == hours)
-                               return (z->dst && (flags & TW_DST) ? z->dst : z->std);
-#endif
        }
 
 #ifdef ADJUST_NUMERIC_ONLY_TZ_OFFSETS_WRT_DST