]> git.sur5r.net Git - cc65/commitdiff
"Inverted" time_t value handling.
authorOliver Schmidt <ol.sc@web.de>
Thu, 2 Aug 2018 15:12:12 +0000 (17:12 +0200)
committerOliver Schmidt <ol.sc@web.de>
Thu, 2 Aug 2018 15:12:12 +0000 (17:12 +0200)
So far time_t values were interpreted as local time values. However, usually time_t values are to be interpreted as "seconds since 1 Jan 1970 in UTC". Therefore all logic handling time_t values has to be changed.

- So far gmtime() called localtime() with an adjusted time_t, now localtime() calls gmtime() with an adjusted time_t.
- mktime() has to do "the opposite" of localtime(), to keep it that way mktime() does now the inverse adjustment made by localtime().
- All currently present time() implementations internally call mktime() so they don't require individual adjustments.

libsrc/common/gmtime.c
libsrc/common/localtime.c
libsrc/common/mktime.c

index 1a2536c5f90186b3f689db6e78ed8c32f648dd25..85e9de3d00461a06bcf50d63dfc4e10fa6c30850 100644 (file)
 
 struct tm* __fastcall__ gmtime (const time_t* timep)
 {
+    static struct tm timebuf;
     time_t t;
 
-    /* Check for a valid time spec */
-    if (timep == 0) {
+    /* Check the argument */
+    if (timep == 0 || (long) (t = *timep) < 0) {
+        /* Invalid arg */
         return 0;
     }
 
-    /* Get the time and correct for the time zone offset */
-    t = *timep + _tz.timezone;
-
-    /* Use localtime for conversion */
-    return localtime (&t);
-}
-
+    /* Since our ints are just 16 bits, split the given time into seconds,
+    ** hours and days. Each of the values will fit in a 16 bit variable.
+    ** The mktime routine will then do the rest.
+    */
+    timebuf.tm_sec  = t % 3600;
+    timebuf.tm_min  = 0;
+    timebuf.tm_hour = (t / 3600) % 24;
+    timebuf.tm_mday = (t / (3600UL * 24UL)) + 1;
+    timebuf.tm_mon  = 0;
+    timebuf.tm_year = 70;       /* Base value is 1/1/1970 */
 
+    /* Call mktime to do the final conversion */
+    mktime (&timebuf);
 
+    /* Return the result */
+    return &timebuf;
+}
index cc6298f8cc33f43bddac5b810c014d1e0e7097a1..48931ea62db944fa621bb95963be2a31781e5d91 100644 (file)
 
 struct tm* __fastcall__ localtime (const time_t* timep)
 {
-    static struct tm timebuf;
     time_t t;
 
-    /* Check the argument */
-    if (timep == 0 || (long) (t = *timep) < 0) {
-        /* Invalid arg */
+    /* Check for a valid time spec */
+    if (timep == 0) {
         return 0;
     }
 
-    /* Since our ints are just 16 bits, split the given time into seconds,
-    ** hours and days. Each of the values will fit in a 16 bit variable.
-    ** The mktime routine will then do the rest.
-    */
-    timebuf.tm_sec  = t % 3600;
-    timebuf.tm_min  = 0;
-    timebuf.tm_hour = (t / 3600) % 24;
-    timebuf.tm_mday = (t / (3600UL * 24UL)) + 1;
-    timebuf.tm_mon  = 0;
-    timebuf.tm_year = 70;       /* Base value is 1/1/1970 */
+    /* Get the time and correct for the time zone offset */
+    t = *timep + _tz.timezone;
 
-    /* Call mktime to do the final conversion */
-    mktime (&timebuf);
-
-    /* Return the result */
-    return &timebuf;
+    /* Use gmtime for conversion */
+    return gmtime (&t);
 }
-
-
index 42372775107fbf3fa2148bd7c6ec0e367ce43dd3..275589dbb6cb875679800046eb6c43af3f867212 100644 (file)
@@ -180,7 +180,8 @@ time_t __fastcall__ mktime (register struct tm* TM)
     return DayCount * 86400UL +
            ((unsigned) TM->tm_hour) * 3600UL +
            ((unsigned) TM->tm_min) * 60U +
-           ((unsigned) TM->tm_sec);
+           ((unsigned) TM->tm_sec) -
+           _tz.timezone;
 
 Error:
     /* Error exit */