Mercurial > repos > devteam > intersect
comparison utils/odict.py @ 0:5b3c6135a982
Imported from capsule None
| author | devteam |
|---|---|
| date | Tue, 01 Apr 2014 10:53:10 -0400 |
| parents | |
| children |
comparison
equal
deleted
inserted
replaced
| -1:000000000000 | 0:5b3c6135a982 |
|---|---|
| 1 """ | |
| 2 Ordered dictionary implementation. | |
| 3 """ | |
| 4 | |
| 5 from UserDict import UserDict | |
| 6 | |
| 7 class odict(UserDict): | |
| 8 """ | |
| 9 http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/107747 | |
| 10 | |
| 11 This dictionary class extends UserDict to record the order in which items are | |
| 12 added. Calling keys(), values(), items(), etc. will return results in this | |
| 13 order. | |
| 14 """ | |
| 15 def __init__( self, dict = None ): | |
| 16 self._keys = [] | |
| 17 UserDict.__init__( self, dict ) | |
| 18 | |
| 19 def __delitem__( self, key ): | |
| 20 UserDict.__delitem__( self, key ) | |
| 21 self._keys.remove( key ) | |
| 22 | |
| 23 def __setitem__( self, key, item ): | |
| 24 UserDict.__setitem__( self, key, item ) | |
| 25 if key not in self._keys: | |
| 26 self._keys.append( key ) | |
| 27 | |
| 28 def clear( self ): | |
| 29 UserDict.clear( self ) | |
| 30 self._keys = [] | |
| 31 | |
| 32 def copy(self): | |
| 33 new = odict() | |
| 34 new.update( self ) | |
| 35 return new | |
| 36 | |
| 37 def items( self ): | |
| 38 return zip( self._keys, self.values() ) | |
| 39 | |
| 40 def keys( self ): | |
| 41 return self._keys[:] | |
| 42 | |
| 43 def popitem( self ): | |
| 44 try: | |
| 45 key = self._keys[-1] | |
| 46 except IndexError: | |
| 47 raise KeyError( 'dictionary is empty' ) | |
| 48 val = self[ key ] | |
| 49 del self[ key ] | |
| 50 return ( key, val ) | |
| 51 | |
| 52 def setdefault( self, key, failobj=None ): | |
| 53 if key not in self._keys: | |
| 54 self._keys.append( key ) | |
| 55 return UserDict.setdefault( self, key, failobj ) | |
| 56 | |
| 57 def update( self, dict ): | |
| 58 for ( key, val ) in dict.items(): | |
| 59 self.__setitem__( key, val ) | |
| 60 | |
| 61 def values( self ): | |
| 62 return map( self.get, self._keys ) | |
| 63 | |
| 64 def iterkeys( self ): | |
| 65 return iter( self._keys ) | |
| 66 | |
| 67 def itervalues( self ): | |
| 68 for key in self._keys: | |
| 69 yield self.get( key ) | |
| 70 | |
| 71 def iteritems( self ): | |
| 72 for key in self._keys: | |
| 73 yield key, self.get( key ) | |
| 74 | |
| 75 def __iter__( self ): | |
| 76 for key in self._keys: | |
| 77 yield key | |
| 78 | |
| 79 def reverse( self ): | |
| 80 self._keys.reverse() | |
| 81 | |
| 82 def insert( self, index, key, item ): | |
| 83 if key not in self._keys: | |
| 84 self._keys.insert( index, key ) | |
| 85 UserDict.__setitem__( self, key, item ) |
