summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBarry Warsaw <barry@python.org>2008-11-20 20:01:57 (GMT)
committerBarry Warsaw <barry@python.org>2008-11-20 20:01:57 (GMT)
commit91cc8fb92b5d59d26cfca0167b32f6f25b453849 (patch)
tree4d63b6dcf6ffb33332ccad8cdb1a4d5fcb1459f6
parent2d1ca2dbabde2ed69e06b50ddb2e87b12958d696 (diff)
downloadcpython-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.py11
-rw-r--r--Objects/typeobject.c5
-rw-r--r--RELNOTES7
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");
diff --git a/RELNOTES b/RELNOTES
index f307f32..15e4e42 100644
--- a/RELNOTES
+++ b/RELNOTES
@@ -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.