summaryrefslogtreecommitdiffstats
path: root/Objects
diff options
context:
space:
mode:
authorKumar Aditya <59607654+kumaraditya303@users.noreply.github.com>2022-02-01 13:40:46 (GMT)
committerGitHub <noreply@github.com>2022-02-01 13:40:46 (GMT)
commitb9ebde8db7e176e021103745cd012bae700828b5 (patch)
tree302788af4dd37048afbf073dc866217f86626077 /Objects
parent108e66b6d23efd0fc2966163ead9434b328c5f17 (diff)
downloadcpython-b9ebde8db7e176e021103745cd012bae700828b5.zip
cpython-b9ebde8db7e176e021103745cd012bae700828b5.tar.gz
cpython-b9ebde8db7e176e021103745cd012bae700828b5.tar.bz2
bpo-46564: do not create frame object for super object (GH-31002)
Diffstat (limited to 'Objects')
-rw-r--r--Objects/typeobject.c20
1 files changed, 8 insertions, 12 deletions
diff --git a/Objects/typeobject.c b/Objects/typeobject.c
index 621ad97..f7e0775 100644
--- a/Objects/typeobject.c
+++ b/Objects/typeobject.c
@@ -9012,7 +9012,7 @@ super_descr_get(PyObject *self, PyObject *obj, PyObject *type)
}
static int
-super_init_without_args(PyFrameObject *f, PyCodeObject *co,
+super_init_without_args(InterpreterFrame *cframe, PyCodeObject *co,
PyTypeObject **type_p, PyObject **obj_p)
{
if (co->co_argcount == 0) {
@@ -9021,13 +9021,13 @@ super_init_without_args(PyFrameObject *f, PyCodeObject *co,
return -1;
}
- assert(f->f_frame->f_code->co_nlocalsplus > 0);
- PyObject *firstarg = _PyFrame_GetLocalsArray(f->f_frame)[0];
+ assert(cframe->f_code->co_nlocalsplus > 0);
+ PyObject *firstarg = _PyFrame_GetLocalsArray(cframe)[0];
// The first argument might be a cell.
if (firstarg != NULL && (_PyLocals_GetKind(co->co_localspluskinds, 0) & CO_FAST_CELL)) {
// "firstarg" is a cell here unless (very unlikely) super()
// was called from the C-API before the first MAKE_CELL op.
- if (f->f_frame->f_lasti >= 0) {
+ if (cframe->f_lasti >= 0) {
assert(_Py_OPCODE(*co->co_firstinstr) == MAKE_CELL || _Py_OPCODE(*co->co_firstinstr) == COPY_FREE_VARS);
assert(PyCell_Check(firstarg));
firstarg = PyCell_GET(firstarg);
@@ -9047,7 +9047,7 @@ super_init_without_args(PyFrameObject *f, PyCodeObject *co,
PyObject *name = PyTuple_GET_ITEM(co->co_localsplusnames, i);
assert(PyUnicode_Check(name));
if (_PyUnicode_EqualToASCIIId(name, &PyId___class__)) {
- PyObject *cell = _PyFrame_GetLocalsArray(f->f_frame)[i];
+ PyObject *cell = _PyFrame_GetLocalsArray(cframe)[i];
if (cell == NULL || !PyCell_Check(cell)) {
PyErr_SetString(PyExc_RuntimeError,
"super(): bad __class__ cell");
@@ -9096,17 +9096,13 @@ super_init(PyObject *self, PyObject *args, PyObject *kwds)
/* Call super(), without args -- fill in from __class__
and first local variable on the stack. */
PyThreadState *tstate = _PyThreadState_GET();
- PyFrameObject *frame = PyThreadState_GetFrame(tstate);
- if (frame == NULL) {
+ InterpreterFrame *cframe = tstate->cframe->current_frame;
+ if (cframe == NULL) {
PyErr_SetString(PyExc_RuntimeError,
"super(): no current frame");
return -1;
}
-
- PyCodeObject *code = PyFrame_GetCode(frame);
- int res = super_init_without_args(frame, code, &type, &obj);
- Py_DECREF(frame);
- Py_DECREF(code);
+ int res = super_init_without_args(cframe, cframe->f_code, &type, &obj);
if (res < 0) {
return -1;