]> granicus.if.org Git - postgresql/commitdiff
Fix overflow check in tm2timestamp (this time for sure).
authorTom Lane <tgl@sss.pgh.pa.us>
Mon, 4 Mar 2013 20:13:31 +0000 (15:13 -0500)
committerTom Lane <tgl@sss.pgh.pa.us>
Mon, 4 Mar 2013 20:13:49 +0000 (15:13 -0500)
I fixed this code back in commit 841b4a2d5, but didn't think carefully
enough about the behavior near zero, which meant it improperly rejected
1999-12-31 24:00:00.  Per report from Magnus Hagander.

src/backend/utils/adt/timestamp.c
src/interfaces/ecpg/pgtypeslib/timestamp.c

index 8593b6b47f4d26710f36c8dc625e9179defb38cf..ab458155ecbf25c5803c74ffd1a94922ca591df8 100644 (file)
@@ -1646,8 +1646,9 @@ tm2timestamp(struct pg_tm * tm, fsec_t fsec, int *tzp, Timestamp *result)
                return -1;
        }
        /* check for just-barely overflow (okay except time-of-day wraps) */
-       if ((*result < 0 && date >= 0) ||
-               (*result >= 0 && date < 0))
+       /* caution: we want to allow 1999-12-31 24:00:00 */
+       if ((*result < 0 && date > 0) ||
+               (*result > 0 && date < -1))
        {
                *result = 0;                    /* keep compiler quiet */
                return -1;
index 36f101bb1c766f216eae7cf8f47a83a41054ea23..cccd2814d2c484a8069762e136fac1afa0692f58 100644 (file)
@@ -76,8 +76,9 @@ tm2timestamp(struct tm * tm, fsec_t fsec, int *tzp, timestamp * result)
        if ((*result - time) / USECS_PER_DAY != dDate)
                return -1;
        /* check for just-barely overflow (okay except time-of-day wraps) */
-       if ((*result < 0 && dDate >= 0) ||
-               (*result >= 0 && dDate < 0))
+       /* caution: we want to allow 1999-12-31 24:00:00 */
+       if ((*result < 0 && dDate > 0) ||
+               (*result > 0 && dDate < -1))
                return -1;
 #else
        *result = dDate * SECS_PER_DAY + time;