diff options
author | Barry Warsaw <barry@python.org> | 2008-11-20 20:01:57 (GMT) |
---|---|---|
committer | Barry Warsaw <barry@python.org> | 2008-11-20 20:01:57 (GMT) |
commit | 91cc8fb92b5d59d26cfca0167b32f6f25b453849 (patch) | |
tree | 4d63b6dcf6ffb33332ccad8cdb1a4d5fcb1459f6 | |
parent | 2d1ca2dbabde2ed69e06b50ddb2e87b12958d696 (diff) | |
download | cpython-91cc8fb92b5d59d26cfca0167b32f6f25b453849.zip cpython-91cc8fb92b5d59d26cfca0167b32f6f25b453849.tar.gz cpython-91cc8fb92b5d59d26cfca0167b32f6f25b453849.tar.bz2 |
Fix for bug 4360 "SystemError when method has both super() & closure". Patch
by amaury.forgeotdarc and reviewed by brett.cannon.
Also add release notes about the known problems with the email package.
-rw-r--r-- | Lib/test/test_super.py | 11 | ||||
-rw-r--r-- | Objects/typeobject.c | 5 | ||||
-rw-r--r-- | RELNOTES | 7 |
3 files changed, 21 insertions, 2 deletions
diff --git a/Lib/test/test_super.py b/Lib/test/test_super.py index 5594b11..5287402 100644 --- a/Lib/test/test_super.py +++ b/Lib/test/test_super.py @@ -70,6 +70,17 @@ class TestSuper(unittest.TestCase): e = E() self.assertEqual(e.cm(), (e, (E, (E, (E, 'A'), 'B'), 'C'), 'D')) + def testSuperWithClosure(self): + # Issue4360: super() did not work in a function that + # contains a closure + class E(A): + def f(self): + def nested(): + self + return super().f() + 'E' + + self.assertEqual(E().f(), 'AE') + def test_main(): support.run_unittest(TestSuper) diff --git a/Objects/typeobject.c b/Objects/typeobject.c index 7f9a26d..b6ffe92 100644 --- a/Objects/typeobject.c +++ b/Objects/typeobject.c @@ -6170,8 +6170,9 @@ super_init(PyObject *self, PyObject *args, PyObject *kwds) assert(PyUnicode_Check(name)); if (!PyUnicode_CompareWithASCIIString(name, "__class__")) { - PyObject *cell = - f->f_localsplus[co->co_nlocals + i]; + Py_ssize_t index = co->co_nlocals + + PyTuple_GET_SIZE(co->co_cellvars) + i; + PyObject *cell = f->f_localsplus[index]; if (cell == NULL || !PyCell_Check(cell)) { PyErr_SetString(PyExc_SystemError, "super(): bad __class__ cell"); @@ -20,3 +20,10 @@ Additional notes for Python 3.0 final If you need bsddb3 support in Python 3.0, you can find it here: http://pypi.python.org/pypi/bsddb3 + +* The email package needs quite a bit of work to make it consistent with + respect to bytes and strings. There have been discussions on + email-sig@python.org about where to go with the email package for 3.0, but + this was not resolved in time for 3.0 final. With enough care though, the + email package in Python 3.0 should be about as usable as it is with Python + 2. |