diff options
author | Robert Haas <rhaas@postgresql.org> | 2011-06-17 14:28:45 -0400 |
---|---|---|
committer | Robert Haas <rhaas@postgresql.org> | 2011-06-17 14:32:14 -0400 |
commit | 925079063fc429b94c52c5f9174c20157bc39e66 (patch) | |
tree | 922bcf0a60ef67fbcf16999edbfb280dc438a0bf /src/backend/utils/adt/int8.c | |
parent | ae31b59512746a2cc397b70b8a05106e7a7f8ed3 (diff) | |
download | postgresql-925079063fc429b94c52c5f9174c20157bc39e66.tar.gz postgresql-925079063fc429b94c52c5f9174c20157bc39e66.zip |
Add overflow checks to int4 and int8 versions of generate_series().
The previous code went into an infinite loop after overflow. In fact,
an overflow is not really an error; it just means that the current
value is the last one we need to return. So, just arrange to stop
immediately when overflow is detected.
Back-patch all the way.
Diffstat (limited to 'src/backend/utils/adt/int8.c')
-rw-r--r-- | src/backend/utils/adt/int8.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/src/backend/utils/adt/int8.c b/src/backend/utils/adt/int8.c index 451916480cd..2e74482979e 100644 --- a/src/backend/utils/adt/int8.c +++ b/src/backend/utils/adt/int8.c @@ -1410,6 +1410,10 @@ generate_series_step_int8(PG_FUNCTION_ARGS) /* increment current in preparation for next iteration */ fctx->current += fctx->step; + /* if next-value computation overflows, this is the final result */ + if (SAMESIGN(result, fctx->step) && !SAMESIGN(result, fctx->current)) + fctx->step = 0; + /* do when there is more left to send */ SRF_RETURN_NEXT(funcctx, Int64GetDatum(result)); } |