aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2013-03-04 15:13:31 -0500
committerTom Lane <tgl@sss.pgh.pa.us>2013-03-04 15:13:49 -0500
commitfa852303f0cda557e620af775c2e96b56eb365ba (patch)
tree7d29039555a9b4b5c4f38291334addd0ad02d726 /src
parentd4f4bdf23a47dc2b6122195bbff4b09c80e7e2f5 (diff)
downloadpostgresql-fa852303f0cda557e620af775c2e96b56eb365ba.tar.gz
postgresql-fa852303f0cda557e620af775c2e96b56eb365ba.zip
Fix overflow check in tm2timestamp (this time for sure).
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.
Diffstat (limited to 'src')
-rw-r--r--src/backend/utils/adt/timestamp.c5
-rw-r--r--src/interfaces/ecpg/pgtypeslib/timestamp.c5
2 files changed, 6 insertions, 4 deletions
diff --git a/src/backend/utils/adt/timestamp.c b/src/backend/utils/adt/timestamp.c
index 8593b6b47f4..ab458155ecb 100644
--- a/src/backend/utils/adt/timestamp.c
+++ b/src/backend/utils/adt/timestamp.c
@@ -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;
diff --git a/src/interfaces/ecpg/pgtypeslib/timestamp.c b/src/interfaces/ecpg/pgtypeslib/timestamp.c
index 36f101bb1c7..cccd2814d2c 100644
--- a/src/interfaces/ecpg/pgtypeslib/timestamp.c
+++ b/src/interfaces/ecpg/pgtypeslib/timestamp.c
@@ -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;