From: Raymond Hettinger Date: Wed, 29 Jun 2011 23:44:36 +0000 (+0100) Subject: Fixup repr for dict_proxy objects. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=bf7a266074b2c4e97f3386dbf2c8dbf12a0514ac;p=python Fixup repr for dict_proxy objects. --- diff --git a/Lib/test/test_descr.py b/Lib/test/test_descr.py index dc18f336df..b5d98900e2 100644 --- a/Lib/test/test_descr.py +++ b/Lib/test/test_descr.py @@ -4589,6 +4589,10 @@ class DictProxyTests(unittest.TestCase): pass self.C = C + def test_repr(self): + self.assertIn('dict_proxy({', repr(vars(self.C))) + self.assertIn("'meth':", repr(vars(self.C))) + def test_iter_keys(self): # Testing dict-proxy iterkeys... keys = [ key for key in self.C.__dict__.iterkeys() ] diff --git a/Misc/NEWS b/Misc/NEWS index 024d38d06a..9f4ecc9e66 100644 --- a/Misc/NEWS +++ b/Misc/NEWS @@ -13,6 +13,8 @@ Core and Builtins the following case: sys.stdin.read() stopped with CTRL+d (end of file), raw_input() interrupted by CTRL+c. +- dict_proxy objects now display their contents rather than just the class name. + Library ------- diff --git a/Objects/descrobject.c b/Objects/descrobject.c index 135b6d2a9a..8e7ea7d25f 100644 --- a/Objects/descrobject.c +++ b/Objects/descrobject.c @@ -801,6 +801,20 @@ proxy_str(proxyobject *pp) return PyObject_Str(pp->dict); } +static PyObject * +proxy_repr(proxyobject *pp) +{ + PyObject *dictrepr; + PyObject *result; + + dictrepr = PyObject_Repr(pp->dict); + if (dictrepr == NULL) + return NULL; + result = PyString_FromFormat("dict_proxy(%s)", PyString_AS_STRING(dictrepr)); + Py_DECREF(dictrepr); + return result; +} + static int proxy_traverse(PyObject *self, visitproc visit, void *arg) { @@ -832,7 +846,7 @@ PyTypeObject PyDictProxy_Type = { 0, /* tp_getattr */ 0, /* tp_setattr */ (cmpfunc)proxy_compare, /* tp_compare */ - 0, /* tp_repr */ + (reprfunc)proxy_repr, /* tp_repr */ 0, /* tp_as_number */ &proxy_as_sequence, /* tp_as_sequence */ &proxy_as_mapping, /* tp_as_mapping */