[Zodb-checkins] SVN: ZODB/trunk/ - fixed the API of the pop()
method on PersistentDict and PersistentMapping
Thomas Lotze
tl at gocept.com
Tue Nov 22 15:55:48 EST 2005
Log message for revision 40330:
- fixed the API of the pop() method on PersistentDict and PersistentMapping
- no longer try to find pop and popitem on UserDict as all supported
Python versions have them
- added a test for the default argument of pop()
- added a NEWS.txt entry about pop()
Changed:
U ZODB/trunk/NEWS.txt
U ZODB/trunk/src/persistent/dict.py
U ZODB/trunk/src/persistent/mapping.py
U ZODB/trunk/src/persistent/tests/test_mapping.py
-=-
Modified: ZODB/trunk/NEWS.txt
===================================================================
--- ZODB/trunk/NEWS.txt 2005-11-22 18:18:36 UTC (rev 40329)
+++ ZODB/trunk/NEWS.txt 2005-11-22 20:55:47 UTC (rev 40330)
@@ -126,6 +126,9 @@
PersistentMapping
-----------------
+- (3.6b3) The ``PersistentMapping`` makes changes by a ``pop()`` method call
+ persistent now.
+
- (3.6a1) The ``PersistentMapping`` class has an ``__iter__()`` method
now, so that objects of this type work well with Python's iteration
protocol. For example, if ``x`` is a ``PersistentMapping`` (or
Modified: ZODB/trunk/src/persistent/dict.py
===================================================================
--- ZODB/trunk/src/persistent/dict.py 2005-11-22 18:18:36 UTC (rev 40329)
+++ ZODB/trunk/src/persistent/dict.py 2005-11-22 20:55:47 UTC (rev 40330)
@@ -73,9 +73,9 @@
self._p_changed = True
return self.__super_setdefault(key, failobj)
- def pop(self, i):
+ def pop(self, key, *args):
self._p_changed = True
- return self.__super_pop(i)
+ return self.__super_pop(key, *args)
def popitem(self):
self._p_changed = True
Modified: ZODB/trunk/src/persistent/mapping.py
===================================================================
--- ZODB/trunk/src/persistent/mapping.py 2005-11-22 18:18:36 UTC (rev 40329)
+++ ZODB/trunk/src/persistent/mapping.py 2005-11-22 20:55:47 UTC (rev 40330)
@@ -41,6 +41,8 @@
__super_clear = UserDict.clear
__super_update = UserDict.update
__super_setdefault = UserDict.setdefault
+ __super_pop = UserDict.pop
+ __super_popitem = UserDict.popitem
def __delitem__(self, key):
self.__super_delitem(key)
@@ -66,23 +68,13 @@
self._p_changed = 1
return self.__super_setdefault(key, failobj)
- try:
- __super_pop = UserDict.pop
- except AttributeError:
- pass
- else:
- def pop(self, i):
- self._p_changed = 1
- return self.__super_pop(i)
+ def pop(self, key, *args):
+ self._p_changed = 1
+ return self.__super_pop(key, *args)
- try:
- __super_popitem = UserDict.popitem
- except AttributeError:
- pass
- else:
- def popitem(self):
- self._p_changed = 1
- return self.__super_popitem()
+ def popitem(self):
+ self._p_changed = 1
+ return self.__super_popitem()
# __iter__ was added in ZODB 3.4.2, but should have been added long
# before. We could inherit from Python's IterableUserDict instead
Modified: ZODB/trunk/src/persistent/tests/test_mapping.py
===================================================================
--- ZODB/trunk/src/persistent/tests/test_mapping.py 2005-11-22 18:18:36 UTC (rev 40329)
+++ ZODB/trunk/src/persistent/tests/test_mapping.py 2005-11-22 20:55:47 UTC (rev 40330)
@@ -1,6 +1,6 @@
##############################################################################
#
-# Copyright (c) 2001, 2002 Zope Corporation and Contributors.
+# Copyright (c) 2005 Zope Corporation and Contributors.
# All Rights Reserved.
#
# This software is subject to the provisions of the Zope Public License,
@@ -136,6 +136,9 @@
else:
raise TestFailed("1 should not be poppable from u2")
+ x = u2.pop(1, 7)
+ eq(x, 7, "u2.pop(1, 7) == 7")
+
# Test popitem
items = u2.items()
More information about the Zodb-checkins
mailing list