aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJoe Conway <mail@joeconway.com>2020-05-28 13:16:47 -0400
committerJoe Conway <mail@joeconway.com>2020-05-28 13:19:00 -0400
commit887cdff4dcbdfbfdbf9a29dfad0edc09c6ec3398 (patch)
treeec70b3fd11083f388e3a1d3197b9205a8bca452e /src
parent5b1c61e8b8f98f4a1c42856819b6dea600669f47 (diff)
downloadpostgresql-887cdff4dcbdfbfdbf9a29dfad0edc09c6ec3398.tar.gz
postgresql-887cdff4dcbdfbfdbf9a29dfad0edc09c6ec3398.zip
Add CHECK_FOR_INTERRUPTS() to the repeat() function
The repeat() function loops for potentially a long time without ever checking for interrupts. This prevents, for example, a query cancel from interrupting until the work is all done. Fix by inserting a CHECK_FOR_INTERRUPTS() into the loop. Backpatch to all supported versions. Discussion: https://www.postgresql.org/message-id/flat/8692553c-7fe8-17d9-cbc1-7cddb758f4c6%40joeconway.com
Diffstat (limited to 'src')
-rw-r--r--src/backend/utils/adt/oracle_compat.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/src/backend/utils/adt/oracle_compat.c b/src/backend/utils/adt/oracle_compat.c
index 0d56dc898ac..76e666474e8 100644
--- a/src/backend/utils/adt/oracle_compat.c
+++ b/src/backend/utils/adt/oracle_compat.c
@@ -17,6 +17,7 @@
#include "common/int.h"
#include "mb/pg_wchar.h"
+#include "miscadmin.h"
#include "utils/builtins.h"
#include "utils/formatting.h"
@@ -1061,6 +1062,7 @@ repeat(PG_FUNCTION_ARGS)
{
memcpy(cp, sp, slen);
cp += slen;
+ CHECK_FOR_INTERRUPTS();
}
PG_RETURN_TEXT_P(result);