Update Changelog
[profile/ivi/libgee.git] / gee / hashmultiset.c
1 /* hashmultiset.c generated by valac 0.18.0, the Vala compiler
2  * generated from hashmultiset.vala, do not modify */
3
4 /* hashmultiset.vala
5  *
6  * Copyright (C) 2009  Ali Sabil
7  *
8  * This library is free software; you can redistribute it and/or
9  * modify it under the terms of the GNU Lesser General Public
10  * License as published by the Free Software Foundation; either
11  * version 2.1 of the License, or (at your option) any later version.
12
13  * This library is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
16  * Lesser General Public License for more details.
17
18  * You should have received a copy of the GNU Lesser General Public
19  * License along with this library; if not, write to the Free Software
20  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301  USA
21  *
22  * Author:
23  *      Ali Sabil <ali.sabil@gmail.com>
24  */
25
26 #include <glib.h>
27 #include <glib-object.h>
28
29
30 #define GEE_TYPE_TRAVERSABLE (gee_traversable_get_type ())
31 #define GEE_TRAVERSABLE(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GEE_TYPE_TRAVERSABLE, GeeTraversable))
32 #define GEE_IS_TRAVERSABLE(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GEE_TYPE_TRAVERSABLE))
33 #define GEE_TRAVERSABLE_GET_INTERFACE(obj) (G_TYPE_INSTANCE_GET_INTERFACE ((obj), GEE_TYPE_TRAVERSABLE, GeeTraversableIface))
34
35 typedef struct _GeeTraversable GeeTraversable;
36 typedef struct _GeeTraversableIface GeeTraversableIface;
37
38 #define GEE_TRAVERSABLE_TYPE_STREAM (gee_traversable_stream_get_type ())
39
40 #define GEE_TYPE_LAZY (gee_lazy_get_type ())
41 #define GEE_LAZY(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GEE_TYPE_LAZY, GeeLazy))
42 #define GEE_LAZY_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GEE_TYPE_LAZY, GeeLazyClass))
43 #define GEE_IS_LAZY(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GEE_TYPE_LAZY))
44 #define GEE_IS_LAZY_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GEE_TYPE_LAZY))
45 #define GEE_LAZY_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GEE_TYPE_LAZY, GeeLazyClass))
46
47 typedef struct _GeeLazy GeeLazy;
48 typedef struct _GeeLazyClass GeeLazyClass;
49
50 #define GEE_TYPE_ITERATOR (gee_iterator_get_type ())
51 #define GEE_ITERATOR(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GEE_TYPE_ITERATOR, GeeIterator))
52 #define GEE_IS_ITERATOR(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GEE_TYPE_ITERATOR))
53 #define GEE_ITERATOR_GET_INTERFACE(obj) (G_TYPE_INSTANCE_GET_INTERFACE ((obj), GEE_TYPE_ITERATOR, GeeIteratorIface))
54
55 typedef struct _GeeIterator GeeIterator;
56 typedef struct _GeeIteratorIface GeeIteratorIface;
57
58 #define GEE_TYPE_ITERABLE (gee_iterable_get_type ())
59 #define GEE_ITERABLE(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GEE_TYPE_ITERABLE, GeeIterable))
60 #define GEE_IS_ITERABLE(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GEE_TYPE_ITERABLE))
61 #define GEE_ITERABLE_GET_INTERFACE(obj) (G_TYPE_INSTANCE_GET_INTERFACE ((obj), GEE_TYPE_ITERABLE, GeeIterableIface))
62
63 typedef struct _GeeIterable GeeIterable;
64 typedef struct _GeeIterableIface GeeIterableIface;
65
66 #define GEE_TYPE_COLLECTION (gee_collection_get_type ())
67 #define GEE_COLLECTION(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GEE_TYPE_COLLECTION, GeeCollection))
68 #define GEE_IS_COLLECTION(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GEE_TYPE_COLLECTION))
69 #define GEE_COLLECTION_GET_INTERFACE(obj) (G_TYPE_INSTANCE_GET_INTERFACE ((obj), GEE_TYPE_COLLECTION, GeeCollectionIface))
70
71 typedef struct _GeeCollection GeeCollection;
72 typedef struct _GeeCollectionIface GeeCollectionIface;
73
74 #define GEE_TYPE_ABSTRACT_COLLECTION (gee_abstract_collection_get_type ())
75 #define GEE_ABSTRACT_COLLECTION(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GEE_TYPE_ABSTRACT_COLLECTION, GeeAbstractCollection))
76 #define GEE_ABSTRACT_COLLECTION_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GEE_TYPE_ABSTRACT_COLLECTION, GeeAbstractCollectionClass))
77 #define GEE_IS_ABSTRACT_COLLECTION(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GEE_TYPE_ABSTRACT_COLLECTION))
78 #define GEE_IS_ABSTRACT_COLLECTION_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GEE_TYPE_ABSTRACT_COLLECTION))
79 #define GEE_ABSTRACT_COLLECTION_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GEE_TYPE_ABSTRACT_COLLECTION, GeeAbstractCollectionClass))
80
81 typedef struct _GeeAbstractCollection GeeAbstractCollection;
82 typedef struct _GeeAbstractCollectionClass GeeAbstractCollectionClass;
83 typedef struct _GeeAbstractCollectionPrivate GeeAbstractCollectionPrivate;
84
85 #define GEE_TYPE_MULTI_SET (gee_multi_set_get_type ())
86 #define GEE_MULTI_SET(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GEE_TYPE_MULTI_SET, GeeMultiSet))
87 #define GEE_IS_MULTI_SET(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GEE_TYPE_MULTI_SET))
88 #define GEE_MULTI_SET_GET_INTERFACE(obj) (G_TYPE_INSTANCE_GET_INTERFACE ((obj), GEE_TYPE_MULTI_SET, GeeMultiSetIface))
89
90 typedef struct _GeeMultiSet GeeMultiSet;
91 typedef struct _GeeMultiSetIface GeeMultiSetIface;
92
93 #define GEE_TYPE_ABSTRACT_MULTI_SET (gee_abstract_multi_set_get_type ())
94 #define GEE_ABSTRACT_MULTI_SET(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GEE_TYPE_ABSTRACT_MULTI_SET, GeeAbstractMultiSet))
95 #define GEE_ABSTRACT_MULTI_SET_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GEE_TYPE_ABSTRACT_MULTI_SET, GeeAbstractMultiSetClass))
96 #define GEE_IS_ABSTRACT_MULTI_SET(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GEE_TYPE_ABSTRACT_MULTI_SET))
97 #define GEE_IS_ABSTRACT_MULTI_SET_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GEE_TYPE_ABSTRACT_MULTI_SET))
98 #define GEE_ABSTRACT_MULTI_SET_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GEE_TYPE_ABSTRACT_MULTI_SET, GeeAbstractMultiSetClass))
99
100 typedef struct _GeeAbstractMultiSet GeeAbstractMultiSet;
101 typedef struct _GeeAbstractMultiSetClass GeeAbstractMultiSetClass;
102 typedef struct _GeeAbstractMultiSetPrivate GeeAbstractMultiSetPrivate;
103
104 #define GEE_TYPE_MAP (gee_map_get_type ())
105 #define GEE_MAP(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GEE_TYPE_MAP, GeeMap))
106 #define GEE_IS_MAP(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GEE_TYPE_MAP))
107 #define GEE_MAP_GET_INTERFACE(obj) (G_TYPE_INSTANCE_GET_INTERFACE ((obj), GEE_TYPE_MAP, GeeMapIface))
108
109 typedef struct _GeeMap GeeMap;
110 typedef struct _GeeMapIface GeeMapIface;
111
112 #define GEE_TYPE_MAP_ITERATOR (gee_map_iterator_get_type ())
113 #define GEE_MAP_ITERATOR(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GEE_TYPE_MAP_ITERATOR, GeeMapIterator))
114 #define GEE_IS_MAP_ITERATOR(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GEE_TYPE_MAP_ITERATOR))
115 #define GEE_MAP_ITERATOR_GET_INTERFACE(obj) (G_TYPE_INSTANCE_GET_INTERFACE ((obj), GEE_TYPE_MAP_ITERATOR, GeeMapIteratorIface))
116
117 typedef struct _GeeMapIterator GeeMapIterator;
118 typedef struct _GeeMapIteratorIface GeeMapIteratorIface;
119
120 #define GEE_TYPE_SET (gee_set_get_type ())
121 #define GEE_SET(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GEE_TYPE_SET, GeeSet))
122 #define GEE_IS_SET(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GEE_TYPE_SET))
123 #define GEE_SET_GET_INTERFACE(obj) (G_TYPE_INSTANCE_GET_INTERFACE ((obj), GEE_TYPE_SET, GeeSetIface))
124
125 typedef struct _GeeSet GeeSet;
126 typedef struct _GeeSetIface GeeSetIface;
127
128 #define GEE_MAP_TYPE_ENTRY (gee_map_entry_get_type ())
129 #define GEE_MAP_ENTRY(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GEE_MAP_TYPE_ENTRY, GeeMapEntry))
130 #define GEE_MAP_ENTRY_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GEE_MAP_TYPE_ENTRY, GeeMapEntryClass))
131 #define GEE_MAP_IS_ENTRY(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GEE_MAP_TYPE_ENTRY))
132 #define GEE_MAP_IS_ENTRY_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GEE_MAP_TYPE_ENTRY))
133 #define GEE_MAP_ENTRY_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GEE_MAP_TYPE_ENTRY, GeeMapEntryClass))
134
135 typedef struct _GeeMapEntry GeeMapEntry;
136 typedef struct _GeeMapEntryClass GeeMapEntryClass;
137
138 #define GEE_TYPE_HASH_MULTI_SET (gee_hash_multi_set_get_type ())
139 #define GEE_HASH_MULTI_SET(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GEE_TYPE_HASH_MULTI_SET, GeeHashMultiSet))
140 #define GEE_HASH_MULTI_SET_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GEE_TYPE_HASH_MULTI_SET, GeeHashMultiSetClass))
141 #define GEE_IS_HASH_MULTI_SET(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GEE_TYPE_HASH_MULTI_SET))
142 #define GEE_IS_HASH_MULTI_SET_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GEE_TYPE_HASH_MULTI_SET))
143 #define GEE_HASH_MULTI_SET_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GEE_TYPE_HASH_MULTI_SET, GeeHashMultiSetClass))
144
145 typedef struct _GeeHashMultiSet GeeHashMultiSet;
146 typedef struct _GeeHashMultiSetClass GeeHashMultiSetClass;
147 typedef struct _GeeHashMultiSetPrivate GeeHashMultiSetPrivate;
148
149 #define GEE_TYPE_ABSTRACT_MAP (gee_abstract_map_get_type ())
150 #define GEE_ABSTRACT_MAP(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GEE_TYPE_ABSTRACT_MAP, GeeAbstractMap))
151 #define GEE_ABSTRACT_MAP_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GEE_TYPE_ABSTRACT_MAP, GeeAbstractMapClass))
152 #define GEE_IS_ABSTRACT_MAP(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GEE_TYPE_ABSTRACT_MAP))
153 #define GEE_IS_ABSTRACT_MAP_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GEE_TYPE_ABSTRACT_MAP))
154 #define GEE_ABSTRACT_MAP_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GEE_TYPE_ABSTRACT_MAP, GeeAbstractMapClass))
155
156 typedef struct _GeeAbstractMap GeeAbstractMap;
157 typedef struct _GeeAbstractMapClass GeeAbstractMapClass;
158
159 #define GEE_TYPE_HASH_MAP (gee_hash_map_get_type ())
160 #define GEE_HASH_MAP(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GEE_TYPE_HASH_MAP, GeeHashMap))
161 #define GEE_HASH_MAP_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GEE_TYPE_HASH_MAP, GeeHashMapClass))
162 #define GEE_IS_HASH_MAP(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GEE_TYPE_HASH_MAP))
163 #define GEE_IS_HASH_MAP_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GEE_TYPE_HASH_MAP))
164 #define GEE_HASH_MAP_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GEE_TYPE_HASH_MAP, GeeHashMapClass))
165
166 typedef struct _GeeHashMap GeeHashMap;
167 typedef struct _GeeHashMapClass GeeHashMapClass;
168 #define _g_object_unref0(var) ((var == NULL) ? NULL : (var = (g_object_unref (var), NULL)))
169
170 typedef gboolean (*GeeForallFunc) (gpointer g, void* user_data);
171 typedef enum  {
172         GEE_TRAVERSABLE_STREAM_YIELD,
173         GEE_TRAVERSABLE_STREAM_CONTINUE,
174         GEE_TRAVERSABLE_STREAM_END
175 } GeeTraversableStream;
176
177 typedef GeeTraversableStream (*GeeStreamFunc) (GeeTraversableStream state, GeeLazy* g, GeeLazy** lazy, void* user_data);
178 struct _GeeIteratorIface {
179         GTypeInterface parent_iface;
180         gboolean (*next) (GeeIterator* self);
181         gboolean (*has_next) (GeeIterator* self);
182         gpointer (*get) (GeeIterator* self);
183         void (*remove) (GeeIterator* self);
184         gboolean (*get_valid) (GeeIterator* self);
185         gboolean (*get_read_only) (GeeIterator* self);
186 };
187
188 typedef gpointer (*GeeFoldFunc) (gpointer g, gpointer a, void* user_data);
189 typedef gpointer (*GeeMapFunc) (gpointer g, void* user_data);
190 typedef gboolean (*GeePredicate) (gconstpointer g, void* user_data);
191 struct _GeeTraversableIface {
192         GTypeInterface parent_iface;
193         GType (*get_g_type) (GeeTraversable* self);
194         GBoxedCopyFunc (*get_g_dup_func) (GeeTraversable* self);
195         GDestroyNotify (*get_g_destroy_func) (GeeTraversable* self);
196         gboolean (*foreach) (GeeTraversable* self, GeeForallFunc f, void* f_target);
197         GeeIterator* (*stream) (GeeTraversable* self, GType a_type, GBoxedCopyFunc a_dup_func, GDestroyNotify a_destroy_func, GeeStreamFunc f, void* f_target, GDestroyNotify f_target_destroy_notify);
198         gpointer (*fold) (GeeTraversable* self, GType a_type, GBoxedCopyFunc a_dup_func, GDestroyNotify a_destroy_func, GeeFoldFunc f, void* f_target, gpointer seed);
199         GeeIterator* (*map) (GeeTraversable* self, GType a_type, GBoxedCopyFunc a_dup_func, GDestroyNotify a_destroy_func, GeeMapFunc f, void* f_target);
200         GeeIterator* (*scan) (GeeTraversable* self, GType a_type, GBoxedCopyFunc a_dup_func, GDestroyNotify a_destroy_func, GeeFoldFunc f, void* f_target, gpointer seed);
201         GeeIterator* (*filter) (GeeTraversable* self, GeePredicate pred, void* pred_target, GDestroyNotify pred_target_destroy_notify);
202         GeeIterator* (*chop) (GeeTraversable* self, gint offset, gint length);
203         GType (*get_element_type) (GeeTraversable* self);
204 };
205
206 struct _GeeIterableIface {
207         GTypeInterface parent_iface;
208         GType (*get_g_type) (GeeIterable* self);
209         GBoxedCopyFunc (*get_g_dup_func) (GeeIterable* self);
210         GDestroyNotify (*get_g_destroy_func) (GeeIterable* self);
211         GeeIterator* (*iterator) (GeeIterable* self);
212 };
213
214 struct _GeeCollectionIface {
215         GTypeInterface parent_iface;
216         GType (*get_g_type) (GeeCollection* self);
217         GBoxedCopyFunc (*get_g_dup_func) (GeeCollection* self);
218         GDestroyNotify (*get_g_destroy_func) (GeeCollection* self);
219         gboolean (*contains) (GeeCollection* self, gconstpointer item);
220         gboolean (*add) (GeeCollection* self, gconstpointer item);
221         gboolean (*remove) (GeeCollection* self, gconstpointer item);
222         void (*clear) (GeeCollection* self);
223         gboolean (*add_all) (GeeCollection* self, GeeCollection* collection);
224         gboolean (*contains_all) (GeeCollection* self, GeeCollection* collection);
225         gboolean (*remove_all) (GeeCollection* self, GeeCollection* collection);
226         gboolean (*retain_all) (GeeCollection* self, GeeCollection* collection);
227         gpointer* (*to_array) (GeeCollection* self, int* result_length1);
228         gint (*get_size) (GeeCollection* self);
229         gboolean (*get_is_empty) (GeeCollection* self);
230         gboolean (*get_read_only) (GeeCollection* self);
231         GeeCollection* (*get_read_only_view) (GeeCollection* self);
232 };
233
234 struct _GeeAbstractCollection {
235         GObject parent_instance;
236         GeeAbstractCollectionPrivate * priv;
237 };
238
239 struct _GeeAbstractCollectionClass {
240         GObjectClass parent_class;
241         gboolean (*contains) (GeeAbstractCollection* self, gconstpointer item);
242         gboolean (*add) (GeeAbstractCollection* self, gconstpointer item);
243         gboolean (*remove) (GeeAbstractCollection* self, gconstpointer item);
244         void (*clear) (GeeAbstractCollection* self);
245         GeeIterator* (*iterator) (GeeAbstractCollection* self);
246         gboolean (*foreach) (GeeAbstractCollection* self, GeeForallFunc f, void* f_target);
247         void (*reserved0) (GeeAbstractCollection* self);
248         void (*reserved1) (GeeAbstractCollection* self);
249         void (*reserved2) (GeeAbstractCollection* self);
250         void (*reserved3) (GeeAbstractCollection* self);
251         void (*reserved4) (GeeAbstractCollection* self);
252         void (*reserved5) (GeeAbstractCollection* self);
253         void (*reserved6) (GeeAbstractCollection* self);
254         void (*reserved7) (GeeAbstractCollection* self);
255         void (*reserved8) (GeeAbstractCollection* self);
256         void (*reserved9) (GeeAbstractCollection* self);
257         gint (*get_size) (GeeAbstractCollection* self);
258         gboolean (*get_read_only) (GeeAbstractCollection* self);
259         GeeCollection* (*get_read_only_view) (GeeAbstractCollection* self);
260 };
261
262 struct _GeeMultiSetIface {
263         GTypeInterface parent_iface;
264         GType (*get_g_type) (GeeMultiSet* self);
265         GBoxedCopyFunc (*get_g_dup_func) (GeeMultiSet* self);
266         GDestroyNotify (*get_g_destroy_func) (GeeMultiSet* self);
267         gint (*count) (GeeMultiSet* self, gconstpointer item);
268         GeeMultiSet* (*get_read_only_view) (GeeMultiSet* self);
269 };
270
271 typedef gpointer (*GeeFoldMapFunc) (gconstpointer k, gconstpointer v, gpointer a, void* user_data);
272 typedef gboolean (*GeeForallMapFunc) (gconstpointer k, gconstpointer v, void* user_data);
273 struct _GeeMapIteratorIface {
274         GTypeInterface parent_iface;
275         GType (*get_k_type) (GeeMapIterator* self);
276         GBoxedCopyFunc (*get_k_dup_func) (GeeMapIterator* self);
277         GDestroyNotify (*get_k_destroy_func) (GeeMapIterator* self);
278         GType (*get_v_type) (GeeMapIterator* self);
279         GBoxedCopyFunc (*get_v_dup_func) (GeeMapIterator* self);
280         GDestroyNotify (*get_v_destroy_func) (GeeMapIterator* self);
281         gboolean (*next) (GeeMapIterator* self);
282         gboolean (*has_next) (GeeMapIterator* self);
283         gpointer (*get_key) (GeeMapIterator* self);
284         gpointer (*get_value) (GeeMapIterator* self);
285         void (*set_value) (GeeMapIterator* self, gconstpointer value);
286         void (*unset) (GeeMapIterator* self);
287         gpointer (*fold) (GeeMapIterator* self, GType a_type, GBoxedCopyFunc a_dup_func, GDestroyNotify a_destroy_func, GeeFoldMapFunc f, void* f_target, gpointer seed);
288         gboolean (*foreach) (GeeMapIterator* self, GeeForallMapFunc f, void* f_target);
289         gboolean (*get_valid) (GeeMapIterator* self);
290         gboolean (*get_mutable) (GeeMapIterator* self);
291         gboolean (*get_read_only) (GeeMapIterator* self);
292 };
293
294 struct _GeeSetIface {
295         GTypeInterface parent_iface;
296         GType (*get_g_type) (GeeSet* self);
297         GBoxedCopyFunc (*get_g_dup_func) (GeeSet* self);
298         GDestroyNotify (*get_g_destroy_func) (GeeSet* self);
299         GeeSet* (*get_read_only_view) (GeeSet* self);
300 };
301
302 struct _GeeMapIface {
303         GTypeInterface parent_iface;
304         GType (*get_k_type) (GeeMap* self);
305         GBoxedCopyFunc (*get_k_dup_func) (GeeMap* self);
306         GDestroyNotify (*get_k_destroy_func) (GeeMap* self);
307         GType (*get_v_type) (GeeMap* self);
308         GBoxedCopyFunc (*get_v_dup_func) (GeeMap* self);
309         GDestroyNotify (*get_v_destroy_func) (GeeMap* self);
310         gboolean (*has_key) (GeeMap* self, gconstpointer key);
311         gboolean (*has) (GeeMap* self, gconstpointer key, gconstpointer value);
312         gpointer (*get) (GeeMap* self, gconstpointer key);
313         void (*set) (GeeMap* self, gconstpointer key, gconstpointer value);
314         gboolean (*unset) (GeeMap* self, gconstpointer key, gpointer* value);
315         void (*clear) (GeeMap* self);
316         GeeMapIterator* (*map_iterator) (GeeMap* self);
317         void (*set_all) (GeeMap* self, GeeMap* map);
318         gboolean (*unset_all) (GeeMap* self, GeeMap* map);
319         gboolean (*has_all) (GeeMap* self, GeeMap* map);
320         gint (*get_size) (GeeMap* self);
321         gboolean (*get_is_empty) (GeeMap* self);
322         gboolean (*get_read_only) (GeeMap* self);
323         GeeSet* (*get_keys) (GeeMap* self);
324         GeeCollection* (*get_values) (GeeMap* self);
325         GeeSet* (*get_entries) (GeeMap* self);
326         GeeMap* (*get_read_only_view) (GeeMap* self);
327 };
328
329 struct _GeeAbstractMultiSet {
330         GeeAbstractCollection parent_instance;
331         GeeAbstractMultiSetPrivate * priv;
332         GeeMap* _storage_map;
333 };
334
335 struct _GeeAbstractMultiSetClass {
336         GeeAbstractCollectionClass parent_class;
337         void (*reserved0) (GeeAbstractMultiSet* self);
338         void (*reserved1) (GeeAbstractMultiSet* self);
339         void (*reserved2) (GeeAbstractMultiSet* self);
340         void (*reserved3) (GeeAbstractMultiSet* self);
341         void (*reserved4) (GeeAbstractMultiSet* self);
342         void (*reserved5) (GeeAbstractMultiSet* self);
343         void (*reserved6) (GeeAbstractMultiSet* self);
344         void (*reserved7) (GeeAbstractMultiSet* self);
345         void (*reserved8) (GeeAbstractMultiSet* self);
346         GeeMultiSet* (*get_read_only_view) (GeeAbstractMultiSet* self);
347 };
348
349 struct _GeeHashMultiSet {
350         GeeAbstractMultiSet parent_instance;
351         GeeHashMultiSetPrivate * priv;
352 };
353
354 struct _GeeHashMultiSetClass {
355         GeeAbstractMultiSetClass parent_class;
356 };
357
358 struct _GeeHashMultiSetPrivate {
359         GType g_type;
360         GBoxedCopyFunc g_dup_func;
361         GDestroyNotify g_destroy_func;
362 };
363
364 typedef guint (*GeeHashDataFunc) (gconstpointer v, void* user_data);
365 typedef gboolean (*GeeEqualDataFunc) (gconstpointer a, gconstpointer b, void* user_data);
366
367 static gpointer gee_hash_multi_set_parent_class = NULL;
368
369 GType gee_traversable_stream_get_type (void) G_GNUC_CONST;
370 gpointer gee_lazy_ref (gpointer instance);
371 void gee_lazy_unref (gpointer instance);
372 GParamSpec* gee_param_spec_lazy (const gchar* name, const gchar* nick, const gchar* blurb, GType object_type, GParamFlags flags);
373 void gee_value_set_lazy (GValue* value, gpointer v_object);
374 void gee_value_take_lazy (GValue* value, gpointer v_object);
375 gpointer gee_value_get_lazy (const GValue* value);
376 GType gee_lazy_get_type (void) G_GNUC_CONST;
377 GType gee_iterator_get_type (void) G_GNUC_CONST;
378 GType gee_traversable_get_type (void) G_GNUC_CONST;
379 GType gee_iterable_get_type (void) G_GNUC_CONST;
380 GType gee_collection_get_type (void) G_GNUC_CONST;
381 GType gee_abstract_collection_get_type (void) G_GNUC_CONST;
382 GType gee_multi_set_get_type (void) G_GNUC_CONST;
383 GType gee_abstract_multi_set_get_type (void) G_GNUC_CONST;
384 GType gee_map_iterator_get_type (void) G_GNUC_CONST;
385 GType gee_set_get_type (void) G_GNUC_CONST;
386 GType gee_map_entry_get_type (void) G_GNUC_CONST;
387 GType gee_map_get_type (void) G_GNUC_CONST;
388 GType gee_hash_multi_set_get_type (void) G_GNUC_CONST;
389 #define GEE_HASH_MULTI_SET_GET_PRIVATE(o) (G_TYPE_INSTANCE_GET_PRIVATE ((o), GEE_TYPE_HASH_MULTI_SET, GeeHashMultiSetPrivate))
390 enum  {
391         GEE_HASH_MULTI_SET_DUMMY_PROPERTY,
392         GEE_HASH_MULTI_SET_G_TYPE,
393         GEE_HASH_MULTI_SET_G_DUP_FUNC,
394         GEE_HASH_MULTI_SET_G_DESTROY_FUNC
395 };
396 GeeHashMultiSet* gee_hash_multi_set_new (GType g_type, GBoxedCopyFunc g_dup_func, GDestroyNotify g_destroy_func, GeeHashDataFunc hash_func, void* hash_func_target, GeeEqualDataFunc equal_func, void* equal_func_target);
397 GeeHashMultiSet* gee_hash_multi_set_construct (GType object_type, GType g_type, GBoxedCopyFunc g_dup_func, GDestroyNotify g_destroy_func, GeeHashDataFunc hash_func, void* hash_func_target, GeeEqualDataFunc equal_func, void* equal_func_target);
398 GeeHashMap* gee_hash_map_new (GType k_type, GBoxedCopyFunc k_dup_func, GDestroyNotify k_destroy_func, GType v_type, GBoxedCopyFunc v_dup_func, GDestroyNotify v_destroy_func, GeeHashDataFunc key_hash_func, void* key_hash_func_target, GDestroyNotify key_hash_func_target_destroy_notify, GeeEqualDataFunc key_equal_func, void* key_equal_func_target, GDestroyNotify key_equal_func_target_destroy_notify, GeeEqualDataFunc value_equal_func, void* value_equal_func_target, GDestroyNotify value_equal_func_target_destroy_notify);
399 GeeHashMap* gee_hash_map_construct (GType object_type, GType k_type, GBoxedCopyFunc k_dup_func, GDestroyNotify k_destroy_func, GType v_type, GBoxedCopyFunc v_dup_func, GDestroyNotify v_destroy_func, GeeHashDataFunc key_hash_func, void* key_hash_func_target, GDestroyNotify key_hash_func_target_destroy_notify, GeeEqualDataFunc key_equal_func, void* key_equal_func_target, GDestroyNotify key_equal_func_target_destroy_notify, GeeEqualDataFunc value_equal_func, void* value_equal_func_target, GDestroyNotify value_equal_func_target_destroy_notify);
400 GType gee_abstract_map_get_type (void) G_GNUC_CONST;
401 GType gee_hash_map_get_type (void) G_GNUC_CONST;
402 GeeAbstractMultiSet* gee_abstract_multi_set_construct (GType object_type, GType g_type, GBoxedCopyFunc g_dup_func, GDestroyNotify g_destroy_func, GeeMap* storage_map);
403 GeeHashDataFunc gee_hash_multi_set_get_hash_func (GeeHashMultiSet* self, gpointer* result_target);
404 GeeHashDataFunc gee_hash_map_get_key_hash_func (GeeHashMap* self, gpointer* result_target);
405 GeeEqualDataFunc gee_hash_multi_set_get_equal_func (GeeHashMultiSet* self, gpointer* result_target);
406 GeeEqualDataFunc gee_hash_map_get_key_equal_func (GeeHashMap* self, gpointer* result_target);
407 static void _vala_gee_hash_multi_set_get_property (GObject * object, guint property_id, GValue * value, GParamSpec * pspec);
408 static void _vala_gee_hash_multi_set_set_property (GObject * object, guint property_id, const GValue * value, GParamSpec * pspec);
409
410
411 /**
412  * Constructs a new, empty hash multi set.
413  *
414  * If not provided, the functions parameters are requested to the
415  * {@link Functions} function factory methods.
416  *
417  * @param hash_func an optional element hash function
418  * @param equal_func an optional element equality testing function
419  */
420 GeeHashMultiSet* gee_hash_multi_set_construct (GType object_type, GType g_type, GBoxedCopyFunc g_dup_func, GDestroyNotify g_destroy_func, GeeHashDataFunc hash_func, void* hash_func_target, GeeEqualDataFunc equal_func, void* equal_func_target) {
421         GeeHashMultiSet * self = NULL;
422         GeeHashDataFunc _tmp0_;
423         void* _tmp0__target;
424         GeeEqualDataFunc _tmp1_;
425         void* _tmp1__target;
426         GeeHashMap* _tmp2_;
427         GeeHashMap* _tmp3_;
428         _tmp0_ = hash_func;
429         _tmp0__target = hash_func_target;
430         _tmp1_ = equal_func;
431         _tmp1__target = equal_func_target;
432         _tmp2_ = gee_hash_map_new (g_type, (GBoxedCopyFunc) g_dup_func, g_destroy_func, G_TYPE_INT, NULL, NULL, _tmp0_, _tmp0__target, NULL, _tmp1_, _tmp1__target, NULL, NULL, NULL, NULL);
433         _tmp3_ = _tmp2_;
434         self = (GeeHashMultiSet*) gee_abstract_multi_set_construct (object_type, g_type, (GBoxedCopyFunc) g_dup_func, g_destroy_func, (GeeMap*) _tmp3_);
435         self->priv->g_type = g_type;
436         self->priv->g_dup_func = g_dup_func;
437         self->priv->g_destroy_func = g_destroy_func;
438         _g_object_unref0 (_tmp3_);
439         return self;
440 }
441
442
443 GeeHashMultiSet* gee_hash_multi_set_new (GType g_type, GBoxedCopyFunc g_dup_func, GDestroyNotify g_destroy_func, GeeHashDataFunc hash_func, void* hash_func_target, GeeEqualDataFunc equal_func, void* equal_func_target) {
444         return gee_hash_multi_set_construct (GEE_TYPE_HASH_MULTI_SET, g_type, g_dup_func, g_destroy_func, hash_func, hash_func_target, equal_func, equal_func_target);
445 }
446
447
448 GeeHashDataFunc gee_hash_multi_set_get_hash_func (GeeHashMultiSet* self, gpointer* result_target) {
449         GeeHashDataFunc result;
450         GeeMap* _tmp0_;
451         GeeHashDataFunc _tmp1_;
452         void* _tmp1__target;
453         GeeHashDataFunc _tmp2_;
454         void* _tmp2__target;
455         GeeHashDataFunc _tmp3_;
456         void* _tmp3__target;
457         g_return_val_if_fail (self != NULL, NULL);
458         _tmp0_ = ((GeeAbstractMultiSet*) self)->_storage_map;
459         _tmp1_ = gee_hash_map_get_key_hash_func (G_TYPE_CHECK_INSTANCE_CAST (_tmp0_, GEE_TYPE_HASH_MAP, GeeHashMap), &_tmp1__target);
460         _tmp2_ = _tmp1_;
461         _tmp2__target = _tmp1__target;
462         _tmp3_ = _tmp2_;
463         _tmp3__target = _tmp2__target;
464         *result_target = _tmp3__target;
465         result = _tmp3_;
466         return result;
467 }
468
469
470 GeeEqualDataFunc gee_hash_multi_set_get_equal_func (GeeHashMultiSet* self, gpointer* result_target) {
471         GeeEqualDataFunc result;
472         GeeMap* _tmp0_;
473         GeeEqualDataFunc _tmp1_;
474         void* _tmp1__target;
475         GeeEqualDataFunc _tmp2_;
476         void* _tmp2__target;
477         GeeEqualDataFunc _tmp3_;
478         void* _tmp3__target;
479         g_return_val_if_fail (self != NULL, NULL);
480         _tmp0_ = ((GeeAbstractMultiSet*) self)->_storage_map;
481         _tmp1_ = gee_hash_map_get_key_equal_func (G_TYPE_CHECK_INSTANCE_CAST (_tmp0_, GEE_TYPE_HASH_MAP, GeeHashMap), &_tmp1__target);
482         _tmp2_ = _tmp1_;
483         _tmp2__target = _tmp1__target;
484         _tmp3_ = _tmp2_;
485         _tmp3__target = _tmp2__target;
486         *result_target = _tmp3__target;
487         result = _tmp3_;
488         return result;
489 }
490
491
492 static void gee_hash_multi_set_class_init (GeeHashMultiSetClass * klass) {
493         gee_hash_multi_set_parent_class = g_type_class_peek_parent (klass);
494         g_type_class_add_private (klass, sizeof (GeeHashMultiSetPrivate));
495         G_OBJECT_CLASS (klass)->get_property = _vala_gee_hash_multi_set_get_property;
496         G_OBJECT_CLASS (klass)->set_property = _vala_gee_hash_multi_set_set_property;
497         g_object_class_install_property (G_OBJECT_CLASS (klass), GEE_HASH_MULTI_SET_G_TYPE, g_param_spec_gtype ("g-type", "type", "type", G_TYPE_NONE, G_PARAM_STATIC_NAME | G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB | G_PARAM_WRITABLE | G_PARAM_CONSTRUCT_ONLY));
498         g_object_class_install_property (G_OBJECT_CLASS (klass), GEE_HASH_MULTI_SET_G_DUP_FUNC, g_param_spec_pointer ("g-dup-func", "dup func", "dup func", G_PARAM_STATIC_NAME | G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB | G_PARAM_WRITABLE | G_PARAM_CONSTRUCT_ONLY));
499         g_object_class_install_property (G_OBJECT_CLASS (klass), GEE_HASH_MULTI_SET_G_DESTROY_FUNC, g_param_spec_pointer ("g-destroy-func", "destroy func", "destroy func", G_PARAM_STATIC_NAME | G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB | G_PARAM_WRITABLE | G_PARAM_CONSTRUCT_ONLY));
500 }
501
502
503 static void gee_hash_multi_set_instance_init (GeeHashMultiSet * self) {
504         self->priv = GEE_HASH_MULTI_SET_GET_PRIVATE (self);
505 }
506
507
508 /**
509  * Hash table implementation of the {@link MultiSet} interface.
510  */
511 GType gee_hash_multi_set_get_type (void) {
512         static volatile gsize gee_hash_multi_set_type_id__volatile = 0;
513         if (g_once_init_enter (&gee_hash_multi_set_type_id__volatile)) {
514                 static const GTypeInfo g_define_type_info = { sizeof (GeeHashMultiSetClass), (GBaseInitFunc) NULL, (GBaseFinalizeFunc) NULL, (GClassInitFunc) gee_hash_multi_set_class_init, (GClassFinalizeFunc) NULL, NULL, sizeof (GeeHashMultiSet), 0, (GInstanceInitFunc) gee_hash_multi_set_instance_init, NULL };
515                 GType gee_hash_multi_set_type_id;
516                 gee_hash_multi_set_type_id = g_type_register_static (GEE_TYPE_ABSTRACT_MULTI_SET, "GeeHashMultiSet", &g_define_type_info, 0);
517                 g_once_init_leave (&gee_hash_multi_set_type_id__volatile, gee_hash_multi_set_type_id);
518         }
519         return gee_hash_multi_set_type_id__volatile;
520 }
521
522
523 static void _vala_gee_hash_multi_set_get_property (GObject * object, guint property_id, GValue * value, GParamSpec * pspec) {
524         GeeHashMultiSet * self;
525         self = G_TYPE_CHECK_INSTANCE_CAST (object, GEE_TYPE_HASH_MULTI_SET, GeeHashMultiSet);
526         switch (property_id) {
527                 default:
528                 G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
529                 break;
530         }
531 }
532
533
534 static void _vala_gee_hash_multi_set_set_property (GObject * object, guint property_id, const GValue * value, GParamSpec * pspec) {
535         GeeHashMultiSet * self;
536         self = G_TYPE_CHECK_INSTANCE_CAST (object, GEE_TYPE_HASH_MULTI_SET, GeeHashMultiSet);
537         switch (property_id) {
538                 case GEE_HASH_MULTI_SET_G_TYPE:
539                 self->priv->g_type = g_value_get_gtype (value);
540                 break;
541                 case GEE_HASH_MULTI_SET_G_DUP_FUNC:
542                 self->priv->g_dup_func = g_value_get_pointer (value);
543                 break;
544                 case GEE_HASH_MULTI_SET_G_DESTROY_FUNC:
545                 self->priv->g_destroy_func = g_value_get_pointer (value);
546                 break;
547                 default:
548                 G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
549                 break;
550         }
551 }
552
553
554