diff options
author | Martin v. Löwis <martin@v.loewis.de> | 2001-02-27 18:36:56 (GMT) |
---|---|---|
committer | Martin v. Löwis <martin@v.loewis.de> | 2001-02-27 18:36:56 (GMT) |
commit | 5e1633365d8a48e96dd4f42c4e7c8729bc62c26d (patch) | |
tree | d743b73ad41520e52d485187e35b1dae577a34f8 /Lib/weakref.py | |
parent | bb40dc48928269d3f60e60e0642b56ecfca2913c (diff) | |
download | cpython-5e1633365d8a48e96dd4f42c4e7c8729bc62c26d.zip cpython-5e1633365d8a48e96dd4f42c4e7c8729bc62c26d.tar.gz cpython-5e1633365d8a48e96dd4f42c4e7c8729bc62c26d.tar.bz2 |
Patch #403985: Add support for weak-keyed dictionaries
Diffstat (limited to 'Lib/weakref.py')
-rw-r--r-- | Lib/weakref.py | 63 |
1 files changed, 60 insertions, 3 deletions
diff --git a/Lib/weakref.py b/Lib/weakref.py index f1222fa..9d5eac0 100644 --- a/Lib/weakref.py +++ b/Lib/weakref.py @@ -20,11 +20,14 @@ from _weakref import \ ProxyTypes = (ProxyType, CallableProxyType) -def mapping(dict=None): - return WeakDictionary(dict) +def mapping(dict=None,weakkeys=0): + if weakkeys: + return WeakKeyDictionary(dict) + else: + return WeakValueDictionary(dict) -class WeakDictionary(UserDict.UserDict): +class WeakValueDictionary(UserDict.UserDict): # We inherit the constructor without worrying about the input # dictionary; since it uses our .update() method, we get the right @@ -112,5 +115,59 @@ class WeakDictionary(UserDict.UserDict): return L +class WeakKeyDictionary(UserDict.UserDict): + + def __init__(self, dict=None): + self.data = {} + if dict is not None: self.update(dict) + def remove(k, data=self.data): + del data[k] + self._remove = remove + + def __getitem__(self, key): + return self.data[ref(key)] + + def __repr__(self): + return "<WeakKeyDictionary at %s>" % id(self) + + def __setitem__(self, key, value): + self.data[ref(key, self._remove)] = value + + def copy(self): + new = WeakKeyDictionary() + for key, value in self.data.items(): + o = key() + if o is not None: + new[o] = value + + def get(self, key, default): + return self.data.get(ref(key),default) + + def items(self): + L = [] + for key, value in self.data.items(): + o = key() + if o is not None: + L.append((o, value)) + return L + + def popitem(self): + while 1: + key, value = self.data.popitem() + o = key() + if o is not None: + return o, value + + def setdefault(self, key, default): + return self.data.setdefault(ref(key, self._remove),default) + + def update(self, dict): + d = self.data + L = [] + for key, value in dict.items(): + L.append(ref(key, self._remove), value) + for key, r in L: + d[key] = r + # no longer needed del UserDict |