Commit 062780ec authored by Robert Haas's avatar Robert Haas

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.
parent bf347c60
...@@ -1382,6 +1382,10 @@ generate_series_step_int4(PG_FUNCTION_ARGS) ...@@ -1382,6 +1382,10 @@ generate_series_step_int4(PG_FUNCTION_ARGS)
/* increment current in preparation for next iteration */ /* increment current in preparation for next iteration */
fctx->current += fctx->step; 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 */ /* do when there is more left to send */
SRF_RETURN_NEXT(funcctx, Int32GetDatum(result)); SRF_RETURN_NEXT(funcctx, Int32GetDatum(result));
} }
......
...@@ -1410,6 +1410,10 @@ generate_series_step_int8(PG_FUNCTION_ARGS) ...@@ -1410,6 +1410,10 @@ generate_series_step_int8(PG_FUNCTION_ARGS)
/* increment current in preparation for next iteration */ /* increment current in preparation for next iteration */
fctx->current += fctx->step; 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 */ /* do when there is more left to send */
SRF_RETURN_NEXT(funcctx, Int64GetDatum(result)); SRF_RETURN_NEXT(funcctx, Int64GetDatum(result));
} }
......
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