]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
* Add clearer comment to initialization code.
authorRaymond Hettinger <python@rcn.com>
Thu, 19 Mar 2009 19:59:58 +0000 (19:59 +0000)
committerRaymond Hettinger <python@rcn.com>
Thu, 19 Mar 2009 19:59:58 +0000 (19:59 +0000)
* Add optional argument to popitem() -- modeled
  after Anthon van der Neut's C version.
* Fix method markup in docs.

Doc/library/collections.rst
Lib/collections.py
Lib/test/test_collections.py

index d6d1b68d0b05f723baa3341c7f547c61cdae8677..32375a2de6dda2196df9d1c7b1cb37048b1009f3 100644 (file)
@@ -858,8 +858,11 @@ the items are returned in the order their keys were first added.
 
    .. versionadded:: 2.7
 
-The :meth:`popitem` method for ordered dictionaries returns and removes the
-last added entry.  The key/value pairs are returned in LIFO order.
+.. method:: OrderedDict.popitem(last=True)
+
+   The :meth:`popitem` method for ordered dictionaries returns and removes
+   a (key, value) pair.  The pairs are returned in LIFO order if *last* is
+   true or FIFO order if false.
 
 Equality tests between :class:`OrderedDict` objects are order-sensitive
 and are implemented as ``list(od1.items())==list(od2.items())``.
@@ -867,3 +870,8 @@ Equality tests between :class:`OrderedDict` objects and other
 :class:`Mapping` objects are order-insensitive like regular dictionaries.
 This allows :class:`OrderedDict` objects to be substituted anywhere a
 regular dictionary is used.
+
+.. seealso::
+
+   `Equivalent OrderedDict recipe <http://code.activestate.com/recipes/576693/>`_
+   that runs on Python 2.4 or later.
index 1193ebf1b2e99dcf91ff503fbf20894dd1120fd0..8c0b4265f4286d798a859d15ba7134b8dca94c2e 100644 (file)
@@ -30,7 +30,7 @@ class OrderedDict(dict, MutableMapping):
 
     def clear(self):
         self.__end = end = []
-        end += [None, end, end]         # null entry
+        end += [None, end, end]         # sentinel node for doubly linked list
         self.__map = {}                 # key --> [key, prev, next]
         dict.clear(self)
 
@@ -61,10 +61,10 @@ class OrderedDict(dict, MutableMapping):
             yield curr[0]
             curr = curr[1]
 
-    def popitem(self):
+    def popitem(self, last=True):
         if not self:
             raise KeyError('dictionary is empty')
-        key = next(reversed(self))
+        key = next(reversed(self)) if last else next(iter(self))
         value = self.pop(key)
         return key, value
 
index f232df4eeef2a24207b4f1964ba7fb857b5e8a6c..9e984ba930d2fc9c72ee6134703b010c13fb911b 100644 (file)
@@ -768,12 +768,19 @@ class TestOrderedDict(unittest.TestCase):
 class GeneralMappingTests(mapping_tests.BasicTestMappingProtocol):
     type2test = OrderedDict
 
+    def test_popitem(self):
+        d = self._empty_mapping()
+        self.assertRaises(KeyError, d.popitem)
+
 class MyOrderedDict(OrderedDict):
     pass
 
 class SubclassMappingTests(mapping_tests.BasicTestMappingProtocol):
     type2test = MyOrderedDict
 
+    def test_popitem(self):
+        d = self._empty_mapping()
+        self.assertRaises(KeyError, d.popitem)
 
 import doctest, collections