Skip to content

Commit 2cbe3a9

Browse files
committed
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
1 parent fa68594 commit 2cbe3a9

File tree

1 file changed

+2
-1
lines changed

1 file changed

+2
-1
lines changed

src/backend/utils/adt/oracle_compat.c

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -18,7 +18,7 @@
1818
#include "utils/builtins.h"
1919
#include "utils/formatting.h"
2020
#include "mb/pg_wchar.h"
21-
21+
#include "miscadmin.h"
2222

2323
static text *dotrim(const char *string, int stringlen,
2424
const char *set, int setlen,
@@ -1068,6 +1068,7 @@ repeat(PG_FUNCTION_ARGS)
10681068
{
10691069
memcpy(cp, sp, slen);
10701070
cp += slen;
1071+
CHECK_FOR_INTERRUPTS();
10711072
}
10721073

10731074
PG_RETURN_TEXT_P(result);

0 commit comments

Comments
 (0)