ยปCore Development>Code coverage>Lib/UserDict.py

Python code coverage for Lib/UserDict.py

#countcontent
1n/a"""A more or less complete user-defined wrapper around dictionary objects."""
2n/a
30class UserDict:
40 def __init__(self, dict=None, **kwargs):
5369 self.data = {}
6369 if dict is not None:
715 self.update(dict)
8369 if len(kwargs):
951 self.update(kwargs)
108 def __repr__(self): return repr(self.data)
110 def __cmp__(self, dict):
12164 if isinstance(dict, UserDict):
1383 return cmp(self.data, dict.data)
14n/a else:
1581 return cmp(self.data, dict)
160 __hash__ = None # Avoid Py3k warning
17334 def __len__(self): return len(self.data)
180 def __getitem__(self, key):
1935791 if key in self.data:
2033381 return self.data[key]
212409 if hasattr(self.__class__, "__missing__"):
222 return self.__class__.__missing__(self, key)
232407 raise KeyError(key)
2412529 def __setitem__(self, key, item): self.data[key] = item
2518 def __delitem__(self, key): del self.data[key]
2677 def clear(self): self.data.clear()
270 def copy(self):
2825 if self.__class__ is UserDict:
291 return UserDict(self.data.copy())
3024 import copy
3124 data = self.data
3224 try:
3324 self.data = {}
3424 c = copy.copy(self)
35n/a finally:
3624 self.data = data
3724 c.update(self)
3824 return c
39973 def keys(self): return self.data.keys()
40127 def items(self): return self.data.items()
417 def iteritems(self): return self.data.iteritems()
422 def iterkeys(self): return self.data.iterkeys()
432 def itervalues(self): return self.data.itervalues()
4424 def values(self): return self.data.values()
4546 def has_key(self, key): return key in self.data
460 def update(self, dict=None, **kwargs):
47123 if dict is None:
485 pass
49118 elif isinstance(dict, UserDict):
5038 self.data.update(dict.data)
5180 elif isinstance(dict, type({})) or not hasattr(dict, 'items'):
5279 self.data.update(dict)
53n/a else:
543 for k, v in dict.items():
552 self[k] = v
56117 if len(kwargs):
574 self.data.update(kwargs)
580 def get(self, key, failobj=None):
5958938 if key not in self:
6056004 return failobj
612934 return self[key]
620 def setdefault(self, key, failobj=None):
6312 if key not in self:
645 self[key] = failobj
6511 return self[key]
660 def pop(self, key, *args):
6714 return self.data.pop(key, *args)
680 def popitem(self):
6916388 return self.data.popitem()
700 def __contains__(self, key):
7163938 return key in self.data
720 @classmethod
730 def fromkeys(cls, iterable, value=None):
7422 d = cls()
7555 for key in iterable:
7635 d[key] = value
7719 return d
78n/a
790class IterableUserDict(UserDict):
800 def __iter__(self):
814 return iter(self.data)
82n/a
830import _abcoll
840_abcoll.MutableMapping.register(IterableUserDict)
85n/a
86n/a
870class DictMixin:
88n/a # Mixin defining all dictionary methods for classes that already have
89n/a # a minimum dictionary interface including getitem, setitem, delitem,
90n/a # and keys. Without knowledge of the subclass constructor, the mixin
91n/a # does not define __init__() or copy(). In addition to the four base
92n/a # methods, progressively more efficiency comes with defining
93n/a # __contains__(), __iter__(), and iteritems().
94n/a
95n/a # second level definitions support higher levels
960 def __iter__(self):
9720934 for k in self.keys():
9820724 yield k
990 def has_key(self, key):
10030 try:
10130 self[key]
10222 except KeyError:
10322 return False
1048 return True
1050 def __contains__(self, key):
10624 return self.has_key(key)
107n/a
108n/a # third level takes advantage of second level definitions
1090 def iteritems(self):
11020948 for k in self:
11120749 yield (k, self[k])
1120 def iterkeys(self):
1138 return self.__iter__()
114n/a
115n/a # fourth level uses definitions from lower levels
1160 def itervalues(self):
11724 for _, v in self.iteritems():
11816 yield v
1190 def values(self):
12033 return [v for _, v in self.iteritems()]
1210 def items(self):
12256 return list(self.iteritems())
1230 def clear(self):
124144 for key in self.keys():
125124 del self[key]
1260 def setdefault(self, key, default=None):
12721 try:
12821 return self[key]
12910 except KeyError:
13010 self[key] = default
13110 return default
1320 def pop(self, key, *args):
13354 if len(args) > 1:
1340 raise TypeError, "pop expected at most 2 arguments, got "\
1350 + repr(1 + len(args))
13654 try:
13754 value = self[key]
13830 except KeyError:
13930 if args:
1409 return args[0]
14121 raise
14224 del self[key]
14324 return value
1440 def popitem(self):
14516403 try:
14616403 k, v = self.iteritems().next()
14715 except StopIteration:
14815 raise KeyError, 'container is empty'
14916388 del self[k]
15016388 return (k, v)
1510 def update(self, other=None, **kwargs):
152n/a # Make progressively weaker assumptions about "other"
153111 if other is None:
15411 pass
155100 elif hasattr(other, 'iteritems'): # iteritems saves memory and lookups
156135 for k, v in other.iteritems():
157109 self[k] = v
15874 elif hasattr(other, 'keys'):
15953 for k in other.keys():
16031 self[k] = other[k]
161n/a else:
16280 for k, v in other:
16335 self[k] = v
16469 if kwargs:
1654 self.update(kwargs)
1660 def get(self, key, default=None):
16713 try:
16813 return self[key]
1699 except KeyError:
1709 return default
1710 def __repr__(self):
1720 return repr(dict(self.iteritems()))
1730 def __cmp__(self, other):
17450 if other is None:
1750 return 1
17650 if isinstance(other, DictMixin):
17730 other = dict(other.iteritems())
17850 return cmp(dict(self.iteritems()), other)
1790 def __len__(self):
18064 return len(self.keys())