Fri Sep 29 03:43:51 1995 Paul Eggert <eggert@twinsun.com>
authorroland <roland>
Fri, 6 Oct 1995 04:50:31 +0000 (04:50 +0000)
committerroland <roland>
Fri, 6 Oct 1995 04:50:31 +0000 (04:50 +0000)
Rewrite mktime from scratch for performance, and for correctness
in the presence of leap seconds.

* time/mktime.c (ydhms_tm_diff, not_equal_tm, print_tm, check_result):
New functions.
(LEAP_SECONDS_POSSIBLE, CHAR_BIT, INT_MIN, INT_MAX,
TIME_T_MIN, TIME_T_MAX, TM_YEAR_BASE, EPOCH_YEAR): New macros.
<limits.h>, <stdlib.h>: New #includes.
(main): Support tests with given broken-down value; support benchmarks.
(__mon_lengths, debugging_enabled, printtm, dist_tm, doit,
do_normalization, normalize, BAD_STRUCT_TM, SKIP_VALUE,
<ctype.h>): Remove.

* time/time.h, time/mktime.c (__mktime_internal): New offset arg.
* time/mktime.c (mktime), time/timegm.c (timegm): Use it.

* time/mktime.c (__mon_yday): New variable; replaces `__mon_lengths'.
time/offtime.c (__offtime), time/tzset.c (compute_change): Use it.

* time/offtime.c (__offtime): Remove useless assignment
`tp->tm_isdst = -1'.

* manual/maint.texi: Update credits.

manual/maint.texi
time/time.h
time/tzset.c

index 49fb6b4..c3e3ee2 100644 (file)
@@ -774,7 +774,7 @@ The startup code to support SunOS shared libraries was contributed by
 Tom Quinn.
 
 @item
-The @code{mktime} function was contributed by Noel Cragg.
+The @code{mktime} function was contributed by Paul Eggert.
 
 @item
 The port to the Sequent Symmetry running Dynix version 3
index 6d52e94..7d90b7a 100644 (file)
@@ -110,10 +110,11 @@ extern time_t mktime __P ((struct tm *__tp));
 
 /* Subroutine of `mktime'.  Return the `time_t' representation of TP and
    normalize TP, given that a `struct tm *' maps to a `time_t' as performed
-   by FUNC.  */
+   by FUNC.  Keep track of next guess for time_t offset in *OFFSET.  */
 extern time_t __mktime_internal __P ((struct tm *__tp,
                                      struct tm *(*__func) (const time_t *,
-                                                           struct tm *)));
+                                                           struct tm *),
+                                     time_t *__offset));
 
 
 /* Format TP into S according to FORMAT.
index ccaffd9..813609c 100644 (file)
@@ -25,7 +25,7 @@ Cambridge, MA 02139, USA.  */
 #include <time.h>
 
 /* Defined in mktime.c.  */
-extern CONST unsigned short int __mon_lengths[2][12];
+extern CONST unsigned short int __mon_yday[2][13];
 
 #define NOID
 #include "tzfile.h"
@@ -403,10 +403,11 @@ DEFUN(compute_change, (rule, year), tz_rule *rule AND int year)
       /* Mm.n.d - Nth "Dth day" of month M.  */
       {
        register int i, d, m1, yy0, yy1, yy2, dow;
+       register CONST unsigned short int *myday =
+         &__mon_yday[__isleap (year)][rule->m];
 
        /* First add SECSPERDAY for each day in months before M.  */
-       for (i = 0; i < rule->m - 1; ++i)
-         t += __mon_lengths[__isleap (year)][i] * SECSPERDAY;
+       t += myday[-1] * SECSPERDAY;
 
        /* Use Zeller's Congruence to get day-of-week of first day of month. */
        m1 = (rule->m + 9) % 12 + 1;
@@ -424,7 +425,7 @@ DEFUN(compute_change, (rule, year), tz_rule *rule AND int year)
          d += 7;
        for (i = 1; i < rule->n; ++i)
          {
-           if (d + 7 >= __mon_lengths[__isleap (year)][rule->m - 1])
+           if (d + 7 >= myday[0] - myday[-1])
              break;
            d += 7;
          }