blob: 5e97817f061ec1bdef90a3709b0f06e182d681a8 [file] [log] [blame]
Guido van Rossum4acc25b2000-02-02 15:10:15 +00001"""A more or less complete user-defined wrapper around dictionary objects."""
Guido van Rossumae3b3a31993-11-30 13:43:54 +00002
3class UserDict:
Raymond Hettinger54405452002-11-22 00:07:40 +00004 def __init__(self, dict=None, **kwargs):
Raymond Hettingere4827eb2002-11-27 08:29:11 +00005 self.data = {}
Raymond Hettinger54405452002-11-22 00:07:40 +00006 if dict is not None:
Raymond Hettingere4827eb2002-11-27 08:29:11 +00007 self.update(dict)
8 if len(kwargs):
9 self.update(kwargs)
Guido van Rossumb94cd961997-06-03 14:10:01 +000010 def __repr__(self): return repr(self.data)
11 def __cmp__(self, dict):
Guido van Rossum1697b9c1999-03-26 15:31:12 +000012 if isinstance(dict, UserDict):
Guido van Rossum45e2fbc1998-03-26 21:13:24 +000013 return cmp(self.data, dict.data)
Guido van Rossum1697b9c1999-03-26 15:31:12 +000014 else:
15 return cmp(self.data, dict)
Guido van Rossumb94cd961997-06-03 14:10:01 +000016 def __len__(self): return len(self.data)
Guido van Rossum1968ad32006-02-25 22:38:04 +000017 def __getitem__(self, key):
18 if key in self.data:
19 return self.data[key]
20 if hasattr(self.__class__, "__missing__"):
21 return self.__class__.__missing__(self, key)
22 raise KeyError(key)
Guido van Rossumb94cd961997-06-03 14:10:01 +000023 def __setitem__(self, key, item): self.data[key] = item
24 def __delitem__(self, key): del self.data[key]
Guido van Rossum1697b9c1999-03-26 15:31:12 +000025 def clear(self): self.data.clear()
Guido van Rossumb94cd961997-06-03 14:10:01 +000026 def copy(self):
Guido van Rossum1697b9c1999-03-26 15:31:12 +000027 if self.__class__ is UserDict:
Raymond Hettinger90145602003-12-21 22:19:08 +000028 return UserDict(self.data.copy())
Guido van Rossum45e2fbc1998-03-26 21:13:24 +000029 import copy
Fred Drake3ce5af72001-11-05 17:40:48 +000030 data = self.data
31 try:
32 self.data = {}
33 c = copy.copy(self)
34 finally:
35 self.data = data
36 c.update(self)
37 return c
Guido van Rossumb94cd961997-06-03 14:10:01 +000038 def keys(self): return self.data.keys()
39 def items(self): return self.data.items()
Fred Drakebedebbd2001-05-03 04:54:41 +000040 def iteritems(self): return self.data.iteritems()
41 def iterkeys(self): return self.data.iterkeys()
42 def itervalues(self): return self.data.itervalues()
Guido van Rossumb94cd961997-06-03 14:10:01 +000043 def values(self): return self.data.values()
44 def has_key(self, key): return self.data.has_key(key)
Raymond Hettinger31017ae2004-03-04 08:25:44 +000045 def update(self, dict=None, **kwargs):
46 if dict is None:
47 pass
48 elif isinstance(dict, UserDict):
Guido van Rossum1697b9c1999-03-26 15:31:12 +000049 self.data.update(dict.data)
Raymond Hettinger31017ae2004-03-04 08:25:44 +000050 elif isinstance(dict, type({})) or not hasattr(dict, 'items'):
Guido van Rossum1697b9c1999-03-26 15:31:12 +000051 self.data.update(dict)
Guido van Rossum45e2fbc1998-03-26 21:13:24 +000052 else:
Guido van Rossum1697b9c1999-03-26 15:31:12 +000053 for k, v in dict.items():
Martin v. Löwisf3b30742001-06-18 01:09:41 +000054 self[k] = v
Raymond Hettinger31017ae2004-03-04 08:25:44 +000055 if len(kwargs):
56 self.data.update(kwargs)
Barry Warsawfc3e61c1997-10-06 17:50:04 +000057 def get(self, key, failobj=None):
Martin v. Löwisf3b30742001-06-18 01:09:41 +000058 if not self.has_key(key):
59 return failobj
60 return self[key]
Guido van Rossum164452c2000-08-08 16:12:54 +000061 def setdefault(self, key, failobj=None):
Martin v. Löwisf3b30742001-06-18 01:09:41 +000062 if not self.has_key(key):
63 self[key] = failobj
64 return self[key]
Raymond Hettingera3e1e4c2003-03-06 23:54:28 +000065 def pop(self, key, *args):
66 return self.data.pop(key, *args)
Guido van Rossum1072c382000-12-12 22:06:00 +000067 def popitem(self):
68 return self.data.popitem()
Tim Petersa3f98d62001-04-21 09:13:15 +000069 def __contains__(self, key):
70 return key in self.data
Guido van Rossum75b64e62005-01-16 00:16:11 +000071 @classmethod
Raymond Hettingere4827eb2002-11-27 08:29:11 +000072 def fromkeys(cls, iterable, value=None):
73 d = cls()
74 for key in iterable:
75 d[key] = value
76 return d
Guido van Rossum2050b652001-08-07 17:40:42 +000077
78class IterableUserDict(UserDict):
Tim Petersa3f98d62001-04-21 09:13:15 +000079 def __iter__(self):
80 return iter(self.data)
Raymond Hettinger79947162002-11-15 06:46:14 +000081
82class DictMixin:
Raymond Hettinger8ddc176e2002-11-18 04:34:10 +000083 # Mixin defining all dictionary methods for classes that already have
84 # a minimum dictionary interface including getitem, setitem, delitem,
85 # and keys. Without knowledge of the subclass constructor, the mixin
86 # does not define __init__() or copy(). In addition to the four base
Barry Warsaw1a177042003-01-31 03:30:09 +000087 # methods, progressively more efficiency comes with defining
Raymond Hettinger8ddc176e2002-11-18 04:34:10 +000088 # __contains__(), __iter__(), and iteritems().
Raymond Hettinger79947162002-11-15 06:46:14 +000089
Raymond Hettinger8ddc176e2002-11-18 04:34:10 +000090 # second level definitions support higher levels
91 def __iter__(self):
92 for k in self.keys():
93 yield k
Raymond Hettinger79947162002-11-15 06:46:14 +000094 def has_key(self, key):
95 try:
96 value = self[key]
97 except KeyError:
98 return False
99 return True
Raymond Hettinger51f3f1b2003-01-22 01:39:06 +0000100 def __contains__(self, key):
101 return self.has_key(key)
Raymond Hettinger79947162002-11-15 06:46:14 +0000102
Raymond Hettinger8ddc176e2002-11-18 04:34:10 +0000103 # third level takes advantage of second level definitions
Raymond Hettinger79947162002-11-15 06:46:14 +0000104 def iteritems(self):
105 for k in self:
106 yield (k, self[k])
Raymond Hettinger51f3f1b2003-01-22 01:39:06 +0000107 def iterkeys(self):
108 return self.__iter__()
Raymond Hettinger79947162002-11-15 06:46:14 +0000109
Raymond Hettinger8ddc176e2002-11-18 04:34:10 +0000110 # fourth level uses definitions from lower levels
Raymond Hettinger79947162002-11-15 06:46:14 +0000111 def itervalues(self):
112 for _, v in self.iteritems():
113 yield v
114 def values(self):
Raymond Hettinger8ddc176e2002-11-18 04:34:10 +0000115 return [v for _, v in self.iteritems()]
Raymond Hettinger79947162002-11-15 06:46:14 +0000116 def items(self):
117 return list(self.iteritems())
118 def clear(self):
119 for key in self.keys():
120 del self[key]
Walter Dörwaldc1399092004-05-27 09:41:04 +0000121 def setdefault(self, key, default=None):
Raymond Hettinger8ddc176e2002-11-18 04:34:10 +0000122 try:
123 return self[key]
124 except KeyError:
Raymond Hettinger79947162002-11-15 06:46:14 +0000125 self[key] = default
Raymond Hettinger8ddc176e2002-11-18 04:34:10 +0000126 return default
Raymond Hettingera3e1e4c2003-03-06 23:54:28 +0000127 def pop(self, key, *args):
128 if len(args) > 1:
129 raise TypeError, "pop expected at most 2 arguments, got "\
130 + repr(1 + len(args))
131 try:
132 value = self[key]
133 except KeyError:
134 if args:
135 return args[0]
136 raise
Raymond Hettinger79947162002-11-15 06:46:14 +0000137 del self[key]
138 return value
139 def popitem(self):
140 try:
141 k, v = self.iteritems().next()
142 except StopIteration:
Raymond Hettinger8ddc176e2002-11-18 04:34:10 +0000143 raise KeyError, 'container is empty'
Raymond Hettinger79947162002-11-15 06:46:14 +0000144 del self[k]
145 return (k, v)
Raymond Hettinger31017ae2004-03-04 08:25:44 +0000146 def update(self, other=None, **kwargs):
Raymond Hettinger8ddc176e2002-11-18 04:34:10 +0000147 # Make progressively weaker assumptions about "other"
Raymond Hettinger31017ae2004-03-04 08:25:44 +0000148 if other is None:
149 pass
150 elif hasattr(other, 'iteritems'): # iteritems saves memory and lookups
Raymond Hettinger8ddc176e2002-11-18 04:34:10 +0000151 for k, v in other.iteritems():
152 self[k] = v
Raymond Hettinger31017ae2004-03-04 08:25:44 +0000153 elif hasattr(other, 'keys'):
Raymond Hettinger8ddc176e2002-11-18 04:34:10 +0000154 for k in other.keys():
155 self[k] = other[k]
Raymond Hettinger31017ae2004-03-04 08:25:44 +0000156 else:
157 for k, v in other:
158 self[k] = v
159 if kwargs:
160 self.update(kwargs)
Raymond Hettinger79947162002-11-15 06:46:14 +0000161 def get(self, key, default=None):
Raymond Hettinger8ddc176e2002-11-18 04:34:10 +0000162 try:
Raymond Hettinger79947162002-11-15 06:46:14 +0000163 return self[key]
Raymond Hettinger8ddc176e2002-11-18 04:34:10 +0000164 except KeyError:
165 return default
Raymond Hettinger79947162002-11-15 06:46:14 +0000166 def __repr__(self):
Raymond Hettinger8ddc176e2002-11-18 04:34:10 +0000167 return repr(dict(self.iteritems()))
168 def __cmp__(self, other):
Raymond Hettingerf477c882003-12-04 20:04:09 +0000169 if other is None:
170 return 1
Raymond Hettinger8ddc176e2002-11-18 04:34:10 +0000171 if isinstance(other, DictMixin):
172 other = dict(other.iteritems())
173 return cmp(dict(self.iteritems()), other)
174 def __len__(self):
175 return len(self.keys())