From: Robert Haas Date: Fri, 17 Jun 2011 18:28:45 +0000 (-0400) Subject: Add overflow checks to int4 and int8 versions of generate_series(). X-Git-Tag: REL8_3_16~40 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=da021016b4903af677daeb5d9b05e1001d57b5e7;p=thirdparty%2Fpostgresql.git 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. --- diff --git a/src/backend/utils/adt/int.c b/src/backend/utils/adt/int.c index 284a5d27a59..7496cd83547 100644 --- a/src/backend/utils/adt/int.c +++ b/src/backend/utils/adt/int.c @@ -1410,6 +1410,10 @@ generate_series_step_int4(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, Int32GetDatum(result)); } diff --git a/src/backend/utils/adt/int8.c b/src/backend/utils/adt/int8.c index 88bf703df67..e288c1dff65 100644 --- a/src/backend/utils/adt/int8.c +++ b/src/backend/utils/adt/int8.c @@ -1230,6 +1230,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)); }