Kaydet (Commit) b9da9bc0 authored tarafından Raymond Hettinger's avatar Raymond Hettinger

Start replacing UserDict.DictMixin with collections.MutableMapping (the bsddb modules are next).

üst 15ebc88d
......@@ -378,6 +378,11 @@ class Mapping(metaclass=ABCMeta):
def values(self):
return ValuesView(self)
def __eq__(self, other):
return set(self) == set(other)
def __ne__(self, other):
return set(self) == set(other)
class MappingView(metaclass=ABCMeta):
......@@ -485,6 +490,13 @@ class MutableMapping(Mapping):
for key, value in kwds.items():
self[key] = value
def setdefault(self, key, default=None):
try:
return self[key]
except KeyError:
self[key] = default
return default
MutableMapping.register(dict)
......
......@@ -38,12 +38,12 @@ if sys.version_info[:3] >= (2, 3, 0):
HIGHEST_PROTOCOL = pickle.HIGHEST_PROTOCOL
def _dumps(object, protocol):
return pickle.dumps(object, protocol=protocol)
from UserDict import DictMixin
from collections import MutableMapping
else:
HIGHEST_PROTOCOL = None
def _dumps(object, protocol):
return pickle.dumps(object, bin=protocol)
class DictMixin: pass
class MutableMapping: pass
from . import db
......
......@@ -23,13 +23,13 @@ is read when the database is opened, and some updates rewrite the whole index)
import io as _io
import os as _os
import UserDict
import collections
_BLOCKSIZE = 512
error = IOError # For anydbm
class _Database(UserDict.DictMixin):
class _Database(collections.MutableMapping):
# The on-disk directory and data files can remain in mutually
# inconsistent states for an arbitrarily long time (see comments
......
......@@ -59,12 +59,12 @@ the persistent dictionary on disk, if feasible).
from pickle import Pickler, Unpickler
from io import BytesIO
import UserDict
import collections
import warnings
__all__ = ["Shelf","BsdDbShelf","DbfilenameShelf","open"]
class Shelf(UserDict.DictMixin):
class Shelf(collections.MutableMapping):
"""Base class for shelf implementations.
This is initialized with a dictionary-like object.
......@@ -81,7 +81,7 @@ class Shelf(UserDict.DictMixin):
self.cache = {}
self.keyencoding = "utf-8"
def keys(self):
def __iter__(self):
for k in self.dict.keys():
yield k.decode(self.keyencoding)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment