]> granicus.if.org Git - python/commitdiff
Issue #17900: Allowed pickling of recursive OrderedDicts. Decreased pickled
authorSerhiy Storchaka <storchaka@gmail.com>
Tue, 21 May 2013 09:47:57 +0000 (12:47 +0300)
committerSerhiy Storchaka <storchaka@gmail.com>
Tue, 21 May 2013 09:47:57 +0000 (12:47 +0300)
size and pickling time.

Lib/collections/__init__.py
Lib/test/test_collections.py
Misc/NEWS

index 5fd54e8d4cb7f6895e8288a3a4a5ca0e28c16e94..e1a075c7585a2585b763ee6760e9857b3f14beaa 100644 (file)
@@ -199,13 +199,10 @@ class OrderedDict(dict):
 
     def __reduce__(self):
         'Return state information for pickling'
-        items = [[k, self[k]] for k in self]
         inst_dict = vars(self).copy()
         for k in vars(OrderedDict()):
             inst_dict.pop(k, None)
-        if inst_dict:
-            return (self.__class__, (items,), inst_dict)
-        return self.__class__, (items,)
+        return self.__class__, (), inst_dict or None, None, iter(self.items())
 
     def copy(self):
         'od.copy() -> a shallow copy of od'
index 803303125944f152db04b66294bce8a097566c9d..8f379eff552cb68b1b363d5f7aefc464bff0aa1f 100644 (file)
@@ -1245,9 +1245,18 @@ class TestOrderedDict(unittest.TestCase):
         # do not save instance dictionary if not needed
         pairs = [('c', 1), ('b', 2), ('a', 3), ('d', 4), ('e', 5), ('f', 6)]
         od = OrderedDict(pairs)
-        self.assertEqual(len(od.__reduce__()), 2)
+        self.assertIsNone(od.__reduce__()[2])
         od.x = 10
-        self.assertEqual(len(od.__reduce__()), 3)
+        self.assertIsNotNone(od.__reduce__()[2])
+
+    def test_pickle_recursive(self):
+        od = OrderedDict()
+        od[1] = od
+        for proto in range(-1, pickle.HIGHEST_PROTOCOL + 1):
+            dup = pickle.loads(pickle.dumps(od, proto))
+            self.assertIsNot(dup, od)
+            self.assertEqual(list(dup.keys()), [1])
+            self.assertIs(dup[1], dup)
 
     def test_repr(self):
         od = OrderedDict([('c', 1), ('b', 2), ('a', 3), ('d', 4), ('e', 5), ('f', 6)])
index acd89e40205b5cbc6bc88ade4bbf83818a9dabfd..2027e65f3e84ebbf7cc45cc7be46a86d68cbe995 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -99,6 +99,9 @@ Core and Builtins
 Library
 -------
 
+- Issue #17900: Allowed pickling of recursive OrderedDicts.  Decreased pickled
+  size and pickling time.
+
 - Issue #17914: Add os.cpu_count(). Patch by Yogesh Chaudhari, based on an
   initial patch by Trent Nelson.