3 ### Common mapping stuff
5 ### (c) 2005 Straylight/Edgeware
8 ###----- Licensing notice ---------------------------------------------------
10 ### This file is part of the Python interface to mLib.
12 ### mLib/Python is free software; you can redistribute it and/or modify
13 ### it under the terms of the GNU General Public License as published by
14 ### the Free Software Foundation; either version 2 of the License, or
15 ### (at your option) any later version.
17 ### mLib/Python is distributed in the hope that it will be useful,
18 ### but WITHOUT ANY WARRANTY; without even the implied warranty of
19 ### MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20 ### GNU General Public License for more details.
22 ### You should have received a copy of the GNU General Public License
23 ### along with mLib/Python; if not, write to the Free Software Foundation,
24 ### Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
28 cdef class _MapIterator:
34 ## Subclasses must implement these
35 cdef int _init(me) except -1:
36 raise TypeError, 'abstract class'
37 cdef void *_find(me, object key, unsigned *f) except NULL:
38 raise SystemError, 'unimplemented _find'
39 cdef object _key(me, void *e):
41 cdef object _value(me, void *e):
43 cdef void _setval(me, void *e, object val):
45 cdef void _del(me, void *e):
47 cdef _MapIterator _iter(me):
48 raise SystemError, 'unimplemented _iter'
51 def __cinit__(me, *hunoz, **hukairz):
53 def __init__(me, stuff = None, **kw):
57 def update(me, stuff = None, **kw):
58 """D.update([MAP], **KW): insert mappings from MAP and KW"""
62 elif hasattr(stuff, 'itemiter'):
63 for k, v in stuff.itemiter:
64 me._setval(me._find(k, &f), v)
65 elif hasattr(stuff, 'keys'):
66 for k in stuff.keys():
67 me._setval(me._find( k, &f), stuff[k])
70 me._setval(me._find(k, &f), v)
71 for k, v in kw.iteritems():
72 me._setval(me._find(k, &f), v)
76 def __getitem__(me, key):
78 e = me._find(key, NULL)
82 def __setitem__(me, key, value):
84 me._setval(me._find(key, &f), value)
85 def __delitem__(me, key):
92 def get(me, key, default = None):
93 """D.get(KEY, [default = None]) -> VALUE: value at KEY, or DEFAULT"""
95 e = me._find(key, NULL)
99 def setdefault(me, key, default = None):
101 D.setdefault(KEY, [default = None]) -> VALUE:
102 return value at key, or store DEFAULT at key and return that"""
105 e = me._find(key, &f)
109 me._setval(e, default)
111 def pop(me, key, default = None):
113 D.pop(KEY, [default = None]) -> VALUE:
114 return value at key or DEFAULT, and remove KEY"""
116 e = me._find(key, NULL)
123 """D.popitem() -> KEY, VALUE: return and remove an association pair"""
129 raise ValueError, 'popitem(): table is empty'
130 return me._key(e), me._value(e)
133 cdef object _list(me, object (*func)(Mapping m, void *e)):
142 l.append(func(me, e))
146 """D.keys() -> LIST: return a list of known keys"""
147 return me._list(_map_key)
149 """D.values() -> LIST: return a list of known values"""
150 return me._list(_map_value)
152 """D.values() -> LIST: return a list of known (KEY, VALUE) pairs"""
153 return me._list(_map_item)
156 """D.clear(): remove all mappings"""
169 return MapKeyIter(me)
171 """D.iterkeys() -> ITER: return iterator over keys"""
172 return MapKeyIter(me)
174 """D.itervalues() -> ITER: return iterator over values"""
175 return MapValueIter(me)
177 """D.iteritems() -> ITER: return iterator over (KEY, VALUE) pairs"""
178 return MapItemIter(me)
180 cdef class MapIterBase:
182 cdef object (*func)(Mapping m, void *e)
184 cdef int _init(me) except -1:
185 raise TypeError, 'abstract class'
196 return me.func(me.m, e)
197 cdef class MapKeyIter (MapIterBase):
198 cdef int _init(me) except -1:
201 cdef class MapValueIter (MapIterBase):
202 cdef int _init(me) except -1:
205 cdef class MapItemIter (MapIterBase):
206 cdef int _init(me) except -1:
210 cdef object _map_key(Mapping m, void *e):
212 cdef object _map_value(Mapping m, void *e):
214 cdef object _map_item(Mapping m, void *e):
215 return m._key(e), m._value(e)
217 ###----- That's all, folks --------------------------------------------------