summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRaymond Hettinger <python@rcn.com>2003-06-30 04:18:48 (GMT)
committerRaymond Hettinger <python@rcn.com>2003-06-30 04:18:48 (GMT)
commitd693a81595ae3c617f5dd20f9a8bf8b7f130683b (patch)
tree9b967125a07413622eac5ed8b65933c378b9cdf5
parent562a855da062202e0af39cb290c3baf7228dc350 (diff)
downloadcpython-d693a81595ae3c617f5dd20f9a8bf8b7f130683b.zip
cpython-d693a81595ae3c617f5dd20f9a8bf8b7f130683b.tar.gz
cpython-d693a81595ae3c617f5dd20f9a8bf8b7f130683b.tar.bz2
Fix SF 762891: "del p[key]" on proxy object raises SystemError()
-rw-r--r--Lib/test/test_weakref.py11
-rw-r--r--Misc/NEWS33
-rw-r--r--Objects/weakrefobject.c6
3 files changed, 49 insertions, 1 deletions
diff --git a/Lib/test/test_weakref.py b/Lib/test/test_weakref.py
index 5969f35..1b450a3 100644
--- a/Lib/test/test_weakref.py
+++ b/Lib/test/test_weakref.py
@@ -226,6 +226,17 @@ class ReferencesTestCase(TestBase):
self.assert_(not hasattr(o, 'foo'),
"object does not reflect attribute removal via proxy")
+ def test_proxy_deletion(self):
+ # Test clearing of SF bug #762891
+ class Foo:
+ result = None
+ def __delitem__(self, accessor):
+ self.result = accessor
+ g = Foo()
+ f = weakref.proxy(g)
+ del f[0]
+ self.assertEqual(f.result, 0)
+
def test_getweakrefcount(self):
o = C()
ref1 = weakref.ref(o)
diff --git a/Misc/NEWS b/Misc/NEWS
index dbd9192..022a1a6 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -4,6 +4,39 @@ Python News
(editors: check NEWS.help for information about editing NEWS using ReST.)
+What's New in Python 2.3 release candidate?
+===========================================
+
+Core and builtins
+-----------------
+
+Extension modules
+-----------------
+
+- weakref.proxy() can now handle "del obj[i]" for proxy objects
+ defining __delitem__. Formerly, it generated a SystemError.
+
+- SSL no longer crashes the interpreter when the remote side disconnects.
+
+Library
+-------
+
+Tools/Demos
+-----------
+
+Build
+-----
+
+C API
+-----
+
+Windows
+-------
+
+Mac
+---
+
+
What's New in Python 2.3 beta 2?
================================
diff --git a/Objects/weakrefobject.c b/Objects/weakrefobject.c
index e26cb65..f5afb53 100644
--- a/Objects/weakrefobject.c
+++ b/Objects/weakrefobject.c
@@ -389,7 +389,11 @@ proxy_setitem(PyWeakReference *proxy, PyObject *key, PyObject *value)
{
if (!proxy_checkref(proxy))
return -1;
- return PyObject_SetItem(PyWeakref_GET_OBJECT(proxy), key, value);
+
+ if (value == NULL)
+ return PyObject_DelItem(PyWeakref_GET_OBJECT(proxy), key);
+ else
+ return PyObject_SetItem(PyWeakref_GET_OBJECT(proxy), key, value);
}
/* iterator slots */