Commit 542eeba2 authored by Tom Lane's avatar Tom Lane

Fix overflow check in tm2timestamp (this time for sure).

I fixed this code back in commit 841b4a2d, 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.
parent 0ea1f6e9
...@@ -1690,8 +1690,9 @@ tm2timestamp(struct pg_tm * tm, fsec_t fsec, int *tzp, Timestamp *result) ...@@ -1690,8 +1690,9 @@ tm2timestamp(struct pg_tm * tm, fsec_t fsec, int *tzp, Timestamp *result)
return -1; return -1;
} }
/* check for just-barely overflow (okay except time-of-day wraps) */ /* check for just-barely overflow (okay except time-of-day wraps) */
if ((*result < 0 && date >= 0) || /* caution: we want to allow 1999-12-31 24:00:00 */
(*result >= 0 && date < 0)) if ((*result < 0 && date > 0) ||
(*result > 0 && date < -1))
{ {
*result = 0; /* keep compiler quiet */ *result = 0; /* keep compiler quiet */
return -1; return -1;
......
...@@ -76,8 +76,9 @@ tm2timestamp(struct tm * tm, fsec_t fsec, int *tzp, timestamp * result) ...@@ -76,8 +76,9 @@ tm2timestamp(struct tm * tm, fsec_t fsec, int *tzp, timestamp * result)
if ((*result - time) / USECS_PER_DAY != dDate) if ((*result - time) / USECS_PER_DAY != dDate)
return -1; return -1;
/* check for just-barely overflow (okay except time-of-day wraps) */ /* check for just-barely overflow (okay except time-of-day wraps) */
if ((*result < 0 && dDate >= 0) || /* caution: we want to allow 1999-12-31 24:00:00 */
(*result >= 0 && dDate < 0)) if ((*result < 0 && dDate > 0) ||
(*result > 0 && dDate < -1))
return -1; return -1;
#else #else
*result = dDate * SECS_PER_DAY + time; *result = dDate * SECS_PER_DAY + time;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment