summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRaymond Hettinger <python@rcn.com>2011-01-01 22:38:00 (GMT)
committerRaymond Hettinger <python@rcn.com>2011-01-01 22:38:00 (GMT)
commit32062e9be78ee49b563d1b7eb290a00e6fe16c0f (patch)
treebff5fdfbf490eb0447c9e1ad19e3816f82e07f91
parent60db46758fa4dd5786a17226794c8b1eaa3c6094 (diff)
downloadcpython-32062e9be78ee49b563d1b7eb290a00e6fe16c0f.zip
cpython-32062e9be78ee49b563d1b7eb290a00e6fe16c0f.tar.gz
cpython-32062e9be78ee49b563d1b7eb290a00e6fe16c0f.tar.bz2
Make it easier to extend OrderedDict without breaking it.
-rw-r--r--Lib/collections.py4
-rw-r--r--Lib/test/test_collections.py8
2 files changed, 10 insertions, 2 deletions
diff --git a/Lib/collections.py b/Lib/collections.py
index c69f4ca..d0a44c2 100644
--- a/Lib/collections.py
+++ b/Lib/collections.py
@@ -52,7 +52,7 @@ class OrderedDict(dict, MutableMapping):
self.__root = root = _proxy(self.__hardroot)
root.prev = root.next = root
self.__map = {}
- self.update(*args, **kwds)
+ self.__update(*args, **kwds)
def __setitem__(self, key, value,
dict_setitem=dict.__setitem__, proxy=_proxy, Link=_Link):
@@ -171,7 +171,7 @@ class OrderedDict(dict, MutableMapping):
size += sizeof(self.__root) * n # proxy objects
return size
- update = MutableMapping.update
+ update = __update = MutableMapping.update
pop = MutableMapping.pop
keys = MutableMapping.keys
values = MutableMapping.values
diff --git a/Lib/test/test_collections.py b/Lib/test/test_collections.py
index 32ce35b..8c95979 100644
--- a/Lib/test/test_collections.py
+++ b/Lib/test/test_collections.py
@@ -1012,6 +1012,14 @@ class TestOrderedDict(unittest.TestCase):
od = OrderedDict(**d)
self.assertGreater(sys.getsizeof(od), sys.getsizeof(d))
+ def test_override_update(self):
+ # Verify that subclasses can override update() without breaking __init__()
+ class MyOD(OrderedDict):
+ def update(self, *args, **kwds):
+ raise Exception()
+ items = [('a', 1), ('c', 3), ('b', 2)]
+ self.assertEqual(list(MyOD(items).items()), items)
+
class GeneralMappingTests(mapping_tests.BasicTestMappingProtocol):
type2test = OrderedDict