From bd6ec4d79e8575df3d08f8a89ba721930032714c Mon Sep 17 00:00:00 2001 From: Serhiy Storchaka Date: Mon, 18 Dec 2017 14:29:12 +0200 Subject: bpo-32365: Fix a reference leak when compile __debug__. (#4916) It was introduced in bpo-27169. --- Python/compile.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/Python/compile.c b/Python/compile.c index 51c9a08..392de40 100644 --- a/Python/compile.c +++ b/Python/compile.c @@ -3094,10 +3094,6 @@ compiler_nameop(struct compiler *c, identifier name, expr_context_ty ctx) PyObject *mangled; /* XXX AugStore isn't used anywhere! */ - mangled = _Py_Mangle(c->u->u_private, name); - if (!mangled) - return 0; - assert(!_PyUnicode_EqualToASCIIString(name, "None") && !_PyUnicode_EqualToASCIIString(name, "True") && !_PyUnicode_EqualToASCIIString(name, "False")); @@ -3107,6 +3103,10 @@ compiler_nameop(struct compiler *c, identifier name, expr_context_ty ctx) return 1; } + mangled = _Py_Mangle(c->u->u_private, name); + if (!mangled) + return 0; + op = 0; optype = OP_NAME; scope = PyST_GetScope(c->u->u_ste, mangled); -- cgit v0.12