]> granicus.if.org Git - postgresql/commitdiff
Add overflow checks to int4 and int8 versions of generate_series().
authorRobert Haas <rhaas@postgresql.org>
Fri, 17 Jun 2011 18:28:45 +0000 (14:28 -0400)
committerRobert Haas <rhaas@postgresql.org>
Fri, 17 Jun 2011 18:32:14 +0000 (14:32 -0400)
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.

src/backend/utils/adt/int.c
src/backend/utils/adt/int8.c

index 019fcaaa36f23296e9ca1482f00cf839574e238a..a367421f82b6550f16477ff089f00ab58be16136 100644 (file)
@@ -1382,6 +1382,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));
        }
index 451916480cd2b094441346f0274dd1721d885541..2e74482979effaf0eb910346e0be1720b7b86438 100644 (file)
@@ -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));
        }