Kaydet (Commit) d66e94d0 authored tarafından Guido van Rossum's avatar Guido van Rossum

Backport r59862 (issue #712900): make long regexp matches interruptable

by signals.
üst 912ba543
...@@ -212,6 +212,8 @@ Library ...@@ -212,6 +212,8 @@ Library
Extension Modules Extension Modules
----------------- -----------------
- Backport r59862 (issue #712900): make long regexp matches interruptable.
- #1940: make it possible to use curses.filter() before curses.initscr() - #1940: make it possible to use curses.filter() before curses.initscr()
as the documentation says. as the documentation says.
......
...@@ -99,6 +99,7 @@ static char copyright[] = ...@@ -99,6 +99,7 @@ static char copyright[] =
#define SRE_ERROR_STATE -2 /* illegal state */ #define SRE_ERROR_STATE -2 /* illegal state */
#define SRE_ERROR_RECURSION_LIMIT -3 /* runaway recursion */ #define SRE_ERROR_RECURSION_LIMIT -3 /* runaway recursion */
#define SRE_ERROR_MEMORY -9 /* out of memory */ #define SRE_ERROR_MEMORY -9 /* out of memory */
#define SRE_ERROR_INTERRUPTED -10 /* signal handler raised exception */
#if defined(VERBOSE) #if defined(VERBOSE)
#define TRACE(v) printf v #define TRACE(v) printf v
...@@ -809,6 +810,7 @@ SRE_MATCH(SRE_STATE* state, SRE_CODE* pattern) ...@@ -809,6 +810,7 @@ SRE_MATCH(SRE_STATE* state, SRE_CODE* pattern)
Py_ssize_t alloc_pos, ctx_pos = -1; Py_ssize_t alloc_pos, ctx_pos = -1;
Py_ssize_t i, ret = 0; Py_ssize_t i, ret = 0;
Py_ssize_t jump; Py_ssize_t jump;
unsigned int sigcount=0;
SRE_MATCH_CONTEXT* ctx; SRE_MATCH_CONTEXT* ctx;
SRE_MATCH_CONTEXT* nextctx; SRE_MATCH_CONTEXT* nextctx;
...@@ -837,6 +839,9 @@ entrance: ...@@ -837,6 +839,9 @@ entrance:
} }
for (;;) { for (;;) {
++sigcount;
if ((0 == (sigcount & 0xfff)) && PyErr_CheckSignals())
RETURN_ERROR(SRE_ERROR_INTERRUPTED);
switch (*ctx->pattern++) { switch (*ctx->pattern++) {
...@@ -1834,6 +1839,9 @@ pattern_error(int status) ...@@ -1834,6 +1839,9 @@ pattern_error(int status)
case SRE_ERROR_MEMORY: case SRE_ERROR_MEMORY:
PyErr_NoMemory(); PyErr_NoMemory();
break; break;
case SRE_ERROR_INTERRUPTED:
/* An exception has already been raised, so let it fly */
break;
default: default:
/* other error codes indicate compiler/engine bugs */ /* other error codes indicate compiler/engine bugs */
PyErr_SetString( PyErr_SetString(
......
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