mirror of
https://github.com/python/cpython.git
synced 2025-11-01 02:38:53 +00:00
Merged revisions 85896 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/py3k ........ r85896 | antoine.pitrou | 2010-10-29 00:56:58 +0200 (ven., 29 oct. 2010) | 4 lines Issue #5437: A preallocated MemoryError instance should not hold traceback data (including local variables caught in the stack trace) alive infinitely. ........
This commit is contained in:
parent
d7a3ab962b
commit
98e2b45297
5 changed files with 132 additions and 35 deletions
|
|
@ -328,29 +328,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;
|
||||
}
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue