diff options
| author | Antoine Pitrou <solipsis@pitrou.net> | 2010-10-28 22:56:58 +0000 | 
|---|---|---|
| committer | Antoine Pitrou <solipsis@pitrou.net> | 2010-10-28 22:56:58 +0000 | 
| commit | 07e20ef50b52d2359213bc5d91f809a76cfd1524 (patch) | |
| tree | 74803fa7efe3959104b0d9760e4cff172e5c3919 /Python/errors.c | |
| parent | 1842d0c4d88fffb5bea53b410acb77796b66bc8b (diff) | |
| download | cpython-git-07e20ef50b52d2359213bc5d91f809a76cfd1524.tar.gz | |
Issue #5437: A preallocated MemoryError instance should not hold traceback
data (including local variables caught in the stack trace) alive infinitely.
Diffstat (limited to 'Python/errors.c')
| -rw-r--r-- | Python/errors.c | 24 | 
1 files changed, 1 insertions, 23 deletions
| diff --git a/Python/errors.c b/Python/errors.c index 04906141d5..d5a6fae0b4 100644 --- a/Python/errors.c +++ b/Python/errors.c @@ -333,29 +333,7 @@ PyErr_BadArgument(void)  PyObject *  PyErr_NoMemory(void)  { -    if (PyErr_ExceptionMatches(PyExc_MemoryError)) -        /* already current */ -        return NULL; - -    /* raise the pre-allocated instance if it still exists */ -    if (PyExc_MemoryErrorInst) -    { -        /* Clear the previous traceback, otherwise it will be appended -         * to the current one. -         * -         * The following statement is not likely to raise any error; -         * if it does, we simply discard it. -         */ -        PyException_SetTraceback(PyExc_MemoryErrorInst, Py_None); - -        PyErr_SetObject(PyExc_MemoryError, PyExc_MemoryErrorInst); -    } -    else -        /* this will probably fail since there's no memory and hee, -           hee, we have to instantiate this class -        */ -        PyErr_SetNone(PyExc_MemoryError); - +    PyErr_SetNone(PyExc_MemoryError);      return NULL;  } | 
