diff options
author | Antoine Pitrou <solipsis@pitrou.net> | 2010-01-14 17:34:48 (GMT) |
---|---|---|
committer | Antoine Pitrou <solipsis@pitrou.net> | 2010-01-14 17:34:48 (GMT) |
commit | 82feb1f360c26c78f0c5159609f3f697008a9238 (patch) | |
tree | c078d382cc4a24d14bae03aea9e7db1e704012fd /Modules/_sre.c | |
parent | 6d4b00ccc15f46702e1ab9242f16f4a80003f95a (diff) | |
download | cpython-82feb1f360c26c78f0c5159609f3f697008a9238.zip cpython-82feb1f360c26c78f0c5159609f3f697008a9238.tar.gz cpython-82feb1f360c26c78f0c5159609f3f697008a9238.tar.bz2 |
Merged revisions 77499 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r77499 | antoine.pitrou | 2010-01-14 18:25:24 +0100 (jeu., 14 janv. 2010) | 4 lines
Issue #3299: Fix possible crash in the _sre module when given bad
argument values in debug mode. Patch by Victor Stinner.
........
Diffstat (limited to 'Modules/_sre.c')
-rw-r--r-- | Modules/_sre.c | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/Modules/_sre.c b/Modules/_sre.c index 596fd19..7b3ee5f 100644 --- a/Modules/_sre.c +++ b/Modules/_sre.c @@ -2674,6 +2674,10 @@ _compile(PyObject* self_, PyObject* args) self = PyObject_NEW_VAR(PatternObject, &Pattern_Type, n); if (!self) return NULL; + self->weakreflist = NULL; + self->pattern = NULL; + self->groupindex = NULL; + self->indexgroup = NULL; self->codesize = n; @@ -2689,7 +2693,7 @@ _compile(PyObject* self_, PyObject* args) } if (PyErr_Occurred()) { - PyObject_DEL(self); + Py_DECREF(self); return NULL; } @@ -3730,7 +3734,7 @@ static void scanner_dealloc(ScannerObject* self) { state_fini(&self->state); - Py_DECREF(self->pattern); + Py_XDECREF(self->pattern); PyObject_DEL(self); } @@ -3860,10 +3864,11 @@ pattern_scanner(PatternObject* pattern, PyObject* args) self = PyObject_NEW(ScannerObject, &Scanner_Type); if (!self) return NULL; + self->pattern = NULL; string = state_init(&self->state, pattern, string, start, end); if (!string) { - PyObject_DEL(self); + Py_DECREF(self); return NULL; } |