MultiKeyDict re-implemented
git-svn-id: svn://svn.cy55.de/Zope3/src/cybertools/trunk@1515 fd906abe-77d9-0310-91a1-e0d9ade77398
This commit is contained in:
parent
430fdd30d0
commit
233344391f
1 changed files with 3 additions and 2 deletions
|
@ -38,9 +38,9 @@ class MultiKeyDict(dict):
|
||||||
assert len(key) == self.keylen
|
assert len(key) == self.keylen
|
||||||
k0 = key[0]
|
k0 = key[0]
|
||||||
if len(key) > 1:
|
if len(key) > 1:
|
||||||
sub = self.submapping.setdefault(k0, MultiKeyDict())
|
sub = self.submapping.setdefault(k0, MultiKeyDict(self.keylen-1))
|
||||||
sub[key[1:]] = value
|
sub[key[1:]] = value
|
||||||
base = super(MultiKeyDict, self).__setitem__(k0, value)
|
super(MultiKeyDict, self).__setitem__(k0, value)
|
||||||
|
|
||||||
def __getitem__(self, key):
|
def __getitem__(self, key):
|
||||||
r = self.get(key, _not_found)
|
r = self.get(key, _not_found)
|
||||||
|
@ -80,3 +80,4 @@ class MultiKeyDict(dict):
|
||||||
def __repr__(self):
|
def __repr__(self):
|
||||||
return ('<MultiKeyDict %s; submapping: %s>'
|
return ('<MultiKeyDict %s; submapping: %s>'
|
||||||
% (super(MultiKeyDict, self).__repr__(), `self.submapping`))
|
% (super(MultiKeyDict, self).__repr__(), `self.submapping`))
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue