Move the initialization of some pointers earlier. The problem is

that if we call Py_DECREF(frame) like we do if allocating locals fails,
frame_dealloc() will try to use these bogus values and crash.
This commit is contained in:
Neal Norwitz 2006-07-21 05:31:02 +00:00
parent 48808a1d6c
commit 1adbb50701
1 changed files with 1 additions and 1 deletions

View File

@ -642,6 +642,7 @@ PyFrame_New(PyThreadState *tstate, PyCodeObject *code, PyObject *globals,
f->f_trace = NULL;
f->f_exc_type = f->f_exc_value = f->f_exc_traceback = NULL;
}
f->f_stacktop = f->f_valuestack;
f->f_builtins = builtins;
Py_XINCREF(back);
f->f_back = back;
@ -672,7 +673,6 @@ PyFrame_New(PyThreadState *tstate, PyCodeObject *code, PyObject *globals,
f->f_lineno = code->co_firstlineno;
f->f_iblock = 0;
f->f_stacktop = f->f_valuestack;
_PyObject_GC_TRACK(f);
return f;
}