Mercurial > pidgin
annotate src/signals.c @ 6547:adf168f002ad
[gaim-migrate @ 7069]
Added gaim_signal_connect_vargs(), which lets you setup a signal callback
function that takes a va_list instead of actual parameters. Useful for
loader plugins.
committer: Tailor Script <tailor@pidgin.im>
author | Christian Hammond <chipx86@chipx86.com> |
---|---|
date | Thu, 21 Aug 2003 07:37:30 +0000 |
parents | e74e378e86bf |
children | 9e4fa4853cfe |
rev | line source |
---|---|
6485 | 1 /** |
6488
e5e8d21bd4d8
[gaim-migrate @ 7002]
Christian Hammond <chipx86@chipx86.com>
parents:
6485
diff
changeset
|
2 * @file signals.c Signal API |
6485 | 3 * @ingroup core |
4 * | |
5 * gaim | |
6 * | |
7 * Copyright (C) 2003 Christian Hammond <chipx86@gnupdate.org> | |
8 * | |
9 * This program is free software; you can redistribute it and/or modify | |
10 * it under the terms of the GNU General Public License as published by | |
11 * the Free Software Foundation; either version 2 of the License, or | |
12 * (at your option) any later version. | |
13 * | |
14 * This program is distributed in the hope that it will be useful, | |
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
17 * GNU General Public License for more details. | |
18 * | |
19 * You should have received a copy of the GNU General Public License | |
20 * along with this program; if not, write to the Free Software | |
21 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | |
22 */ | |
23 #include "internal.h" | |
24 | |
25 #include "debug.h" | |
26 #include "signals.h" | |
27 | |
28 typedef struct | |
29 { | |
30 void *instance; | |
31 | |
32 GHashTable *signals; | |
33 size_t signal_count; | |
34 | |
35 gulong next_signal_id; | |
36 | |
37 } GaimInstanceData; | |
38 | |
39 typedef struct | |
40 { | |
41 gulong id; | |
42 | |
43 GaimSignalMarshalFunc marshal; | |
44 | |
45 GList *handlers; | |
46 size_t handler_count; | |
47 | |
48 gulong next_handler_id; | |
49 | |
50 } GaimSignalData; | |
51 | |
52 typedef struct | |
53 { | |
54 gulong id; | |
55 GaimCallback cb; | |
56 void *handle; | |
57 void *data; | |
6547
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
58 gboolean use_vargs; |
6485 | 59 |
60 } GaimSignalHandlerData; | |
61 | |
62 static GHashTable *instance_table = NULL; | |
63 | |
64 static void | |
65 destroy_instance_data(GaimInstanceData *instance_data) | |
66 { | |
67 g_hash_table_destroy(instance_data->signals); | |
68 | |
69 g_free(instance_data); | |
70 } | |
71 | |
72 static void | |
73 destroy_signal_data(GaimSignalData *signal_data) | |
74 { | |
75 GaimSignalHandlerData *handler_data; | |
76 GList *l; | |
77 | |
78 for (l = signal_data->handlers; l != NULL; l = l->next) | |
79 { | |
80 handler_data = (GaimSignalHandlerData *)l->data; | |
81 | |
82 g_free(l->data); | |
83 } | |
84 | |
85 g_list_free(signal_data->handlers); | |
86 | |
87 g_free(signal_data); | |
88 } | |
89 | |
90 gulong | |
91 gaim_signal_register(void *instance, const char *signal, | |
92 GaimSignalMarshalFunc marshal) | |
93 { | |
94 GaimInstanceData *instance_data; | |
95 GaimSignalData *signal_data; | |
96 | |
97 g_return_val_if_fail(instance != NULL, 0); | |
98 g_return_val_if_fail(signal != NULL, 0); | |
99 g_return_val_if_fail(marshal != NULL, 0); | |
100 | |
101 instance_data = | |
102 (GaimInstanceData *)g_hash_table_lookup(instance_table, instance); | |
103 | |
104 if (instance_data == NULL) | |
105 { | |
106 instance_data = g_new0(GaimInstanceData, 1); | |
107 | |
108 instance_data->instance = instance; | |
109 instance_data->next_signal_id = 1; | |
110 | |
111 instance_data->signals = | |
112 g_hash_table_new_full(g_str_hash, g_str_equal, g_free, | |
113 (GDestroyNotify)destroy_signal_data); | |
114 | |
115 g_hash_table_insert(instance_table, instance, instance_data); | |
116 } | |
117 | |
118 signal_data = g_new0(GaimSignalData, 1); | |
119 signal_data->id = instance_data->next_signal_id; | |
120 signal_data->marshal = marshal; | |
121 signal_data->next_handler_id = 1; | |
122 | |
123 g_hash_table_insert(instance_data->signals, | |
124 g_strdup(signal), signal_data); | |
125 | |
126 instance_data->next_signal_id++; | |
127 instance_data->signal_count++; | |
128 | |
129 return signal_data->id; | |
130 } | |
131 | |
132 void | |
133 gaim_signal_unregister(void *instance, const char *signal) | |
134 { | |
135 GaimInstanceData *instance_data; | |
136 | |
137 g_return_if_fail(instance != NULL); | |
138 g_return_if_fail(signal != NULL); | |
139 | |
140 instance_data = | |
141 (GaimInstanceData *)g_hash_table_lookup(instance_table, instance); | |
142 | |
143 g_return_if_fail(instance_data != NULL); | |
144 | |
145 g_hash_table_remove(instance_data->signals, signal); | |
146 | |
147 instance_data->signal_count--; | |
148 | |
149 if (instance_data->signal_count == 0) | |
150 { | |
151 /* Unregister the instance. */ | |
152 g_hash_table_remove(instance_table, instance); | |
153 } | |
154 } | |
155 | |
156 void | |
157 gaim_signals_unregister_by_instance(void *instance) | |
158 { | |
159 gboolean found; | |
160 | |
161 g_return_if_fail(instance != NULL); | |
162 | |
163 found = g_hash_table_remove(instance_table, instance); | |
164 | |
165 /* | |
166 * Makes things easier (more annoying?) for developers who don't have | |
167 * things registering and unregistering in the right order :) | |
168 */ | |
169 g_return_if_fail(found); | |
170 } | |
171 | |
6547
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
172 static gulong |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
173 signal_connect_common(void *instance, const char *signal, void *handle, |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
174 GaimCallback func, void *data, gboolean use_vargs) |
6485 | 175 { |
176 GaimInstanceData *instance_data; | |
177 GaimSignalData *signal_data; | |
178 GaimSignalHandlerData *handler_data; | |
179 | |
180 g_return_val_if_fail(instance != NULL, 0); | |
181 g_return_val_if_fail(signal != NULL, 0); | |
182 g_return_val_if_fail(handle != NULL, 0); | |
183 g_return_val_if_fail(func != NULL, 0); | |
184 | |
185 /* Get the instance data */ | |
186 instance_data = | |
187 (GaimInstanceData *)g_hash_table_lookup(instance_table, instance); | |
188 | |
189 g_return_val_if_fail(instance_data != NULL, 0); | |
190 | |
191 /* Get the signal data */ | |
192 signal_data = | |
193 (GaimSignalData *)g_hash_table_lookup(instance_data->signals, signal); | |
194 | |
195 if (signal_data == NULL) | |
196 { | |
197 gaim_debug(GAIM_DEBUG_ERROR, "signals", | |
198 "Signal data for %s not found!\n", signal); | |
199 return 0; | |
200 } | |
201 | |
202 /* Create the signal handler data */ | |
203 handler_data = g_new0(GaimSignalHandlerData, 1); | |
6547
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
204 handler_data->id = signal_data->next_handler_id; |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
205 handler_data->cb = func; |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
206 handler_data->handle = handle; |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
207 handler_data->data = data; |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
208 handler_data->use_vargs = use_vargs; |
6485 | 209 |
210 signal_data->handlers = g_list_append(signal_data->handlers, handler_data); | |
211 signal_data->handler_count++; | |
212 signal_data->next_handler_id++; | |
213 | |
214 return handler_data->id; | |
215 } | |
6547
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
216 gulong |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
217 gaim_signal_connect(void *instance, const char *signal, void *handle, |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
218 GaimCallback func, void *data) |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
219 { |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
220 return signal_connect_common(instance, signal, handle, func, data, FALSE); |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
221 } |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
222 |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
223 gulong |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
224 gaim_signal_connect_vargs(void *instance, const char *signal, void *handle, |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
225 GaimCallback func, void *data) |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
226 { |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
227 return signal_connect_common(instance, signal, handle, func, data, TRUE); |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
228 } |
6485 | 229 |
230 void | |
231 gaim_signal_disconnect(void *instance, const char *signal, | |
232 void *handle, GaimCallback func) | |
233 { | |
234 GaimInstanceData *instance_data; | |
235 GaimSignalData *signal_data; | |
236 GaimSignalHandlerData *handler_data; | |
237 GList *l; | |
238 gboolean found = FALSE; | |
239 | |
240 g_return_if_fail(instance != NULL); | |
241 g_return_if_fail(signal != NULL); | |
242 g_return_if_fail(handle != NULL); | |
243 g_return_if_fail(func != NULL); | |
244 | |
245 /* Get the instance data */ | |
246 instance_data = | |
247 (GaimInstanceData *)g_hash_table_lookup(instance_table, instance); | |
248 | |
249 g_return_if_fail(instance_data != NULL); | |
250 | |
251 /* Get the signal data */ | |
252 signal_data = | |
253 (GaimSignalData *)g_hash_table_lookup(instance_data->signals, signal); | |
254 | |
255 if (signal_data == NULL) | |
256 { | |
257 gaim_debug(GAIM_DEBUG_ERROR, "signals", | |
258 "Signal data for %s not found!\n", signal); | |
259 return; | |
260 } | |
261 | |
262 /* Find the handler data. */ | |
263 for (l = signal_data->handlers; l != NULL; l = l->next) | |
264 { | |
265 handler_data = (GaimSignalHandlerData *)l->data; | |
266 | |
267 if (handler_data->handle == handle && handler_data->cb == func) | |
268 { | |
269 g_free(handler_data); | |
270 | |
271 signal_data->handlers = g_list_remove(signal_data->handlers, | |
272 handler_data); | |
273 signal_data->handler_count--; | |
274 | |
275 found = TRUE; | |
276 | |
277 break; | |
278 } | |
279 } | |
280 | |
281 /* See note somewhere about this actually helping developers.. */ | |
282 g_return_if_fail(found); | |
283 } | |
284 | |
285 /* | |
286 * TODO: Make this all more efficient by storing a list of handlers, keyed | |
287 * to a handle. | |
288 */ | |
289 static void | |
290 disconnect_handle_from_signals(const char *signal, | |
291 GaimSignalData *signal_data, void *handle) | |
292 { | |
293 GList *l, *l_next; | |
294 GaimSignalHandlerData *handler_data; | |
295 | |
296 for (l = signal_data->handlers; l != NULL; l = l_next) | |
297 { | |
298 handler_data = (GaimSignalHandlerData *)l->data; | |
299 l_next = l->next; | |
300 | |
301 if (handler_data->handle == handle) | |
302 { | |
303 g_free(handler_data); | |
304 | |
305 signal_data->handler_count--; | |
306 signal_data->handlers = g_list_remove(signal_data->handlers, | |
307 handler_data); | |
308 } | |
309 } | |
310 } | |
311 | |
312 static void | |
313 disconnect_handle_from_instance(void *instance, | |
314 GaimInstanceData *instance_data, | |
315 void *handle) | |
316 { | |
317 g_hash_table_foreach(instance_data->signals, | |
318 (GHFunc)disconnect_handle_from_signals, handle); | |
319 } | |
320 | |
321 void | |
322 gaim_signals_disconnect_by_handle(void *handle) | |
323 { | |
324 g_return_if_fail(handle != NULL); | |
325 | |
326 g_hash_table_foreach(instance_table, | |
327 (GHFunc)disconnect_handle_from_instance, handle); | |
328 } | |
329 | |
330 void | |
331 gaim_signal_emit(void *instance, const char *signal, ...) | |
332 { | |
333 va_list args; | |
334 | |
335 va_start(args, signal); | |
336 gaim_signal_emit_vargs(instance, signal, args); | |
337 va_end(args); | |
338 } | |
339 | |
340 void | |
341 gaim_signal_emit_vargs(void *instance, const char *signal, va_list args) | |
342 { | |
343 GaimInstanceData *instance_data; | |
344 GaimSignalData *signal_data; | |
345 GaimSignalHandlerData *handler_data; | |
346 GList *l; | |
347 | |
348 g_return_if_fail(instance != NULL); | |
349 g_return_if_fail(signal != NULL); | |
350 | |
351 instance_data = | |
352 (GaimInstanceData *)g_hash_table_lookup(instance_table, instance); | |
353 | |
354 g_return_if_fail(instance_data != NULL); | |
355 | |
356 signal_data = | |
357 (GaimSignalData *)g_hash_table_lookup(instance_data->signals, signal); | |
358 | |
359 if (signal_data == NULL) | |
360 { | |
361 gaim_debug(GAIM_DEBUG_ERROR, "signals", | |
362 "Signal data for %s not found!\n", signal); | |
363 return; | |
364 } | |
365 | |
366 for (l = signal_data->handlers; l != NULL; l = l->next) | |
367 { | |
368 handler_data = (GaimSignalHandlerData *)l->data; | |
369 | |
6547
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
370 if (handler_data->use_vargs) |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
371 { |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
372 ((void (*)(va_list, void *))handler_data->cb)(args, |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
373 handler_data->data); |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
374 } |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
375 else |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
376 { |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
377 signal_data->marshal(handler_data->cb, args, |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
378 handler_data->data, NULL); |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
379 } |
6485 | 380 } |
381 } | |
382 | |
383 void * | |
384 gaim_signal_emit_return_1(void *instance, const char *signal, ...) | |
385 { | |
386 void *ret_val; | |
387 va_list args; | |
388 | |
389 va_start(args, signal); | |
390 ret_val = gaim_signal_emit_vargs_return_1(instance, signal, args); | |
391 va_end(args); | |
392 | |
393 return ret_val; | |
394 } | |
395 | |
396 void * | |
397 gaim_signal_emit_vargs_return_1(void *instance, const char *signal, | |
398 va_list args) | |
399 { | |
400 GaimInstanceData *instance_data; | |
401 GaimSignalData *signal_data; | |
402 GaimSignalHandlerData *handler_data; | |
403 void *ret_val = NULL; | |
404 GList *l; | |
405 | |
406 g_return_val_if_fail(instance != NULL, NULL); | |
407 g_return_val_if_fail(signal != NULL, NULL); | |
408 | |
409 instance_data = | |
410 (GaimInstanceData *)g_hash_table_lookup(instance_table, instance); | |
411 | |
412 g_return_val_if_fail(instance_data != NULL, NULL); | |
413 | |
414 signal_data = | |
415 (GaimSignalData *)g_hash_table_lookup(instance_data->signals, signal); | |
416 | |
417 if (signal_data == NULL) | |
418 { | |
419 gaim_debug(GAIM_DEBUG_ERROR, "signals", | |
420 "Signal data for %s not found!\n", signal); | |
421 return 0; | |
422 } | |
423 | |
424 for (l = signal_data->handlers; l != NULL; l = l->next) | |
425 { | |
426 handler_data = (GaimSignalHandlerData *)l->data; | |
427 | |
6547
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
428 if (handler_data->use_vargs) |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
429 { |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
430 ret_val = ((void *(*)(va_list, void *))handler_data->cb)( |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
431 args, handler_data->data); |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
432 } |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
433 else |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
434 { |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
435 signal_data->marshal(handler_data->cb, args, |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
436 handler_data->data, &ret_val); |
adf168f002ad
[gaim-migrate @ 7069]
Christian Hammond <chipx86@chipx86.com>
parents:
6509
diff
changeset
|
437 } |
6485 | 438 } |
439 | |
440 return ret_val; | |
441 } | |
442 | |
443 void | |
444 gaim_signals_init() | |
445 { | |
446 g_return_if_fail(instance_table == NULL); | |
447 | |
448 instance_table = | |
449 g_hash_table_new_full(g_direct_hash, g_direct_equal, | |
450 NULL, (GDestroyNotify)destroy_instance_data); | |
451 } | |
452 | |
453 void | |
454 gaim_signals_uninit() | |
455 { | |
456 g_return_if_fail(instance_table != NULL); | |
457 | |
458 g_hash_table_destroy(instance_table); | |
459 instance_table = NULL; | |
460 } | |
461 | |
462 /************************************************************************** | |
463 * Marshallers | |
464 **************************************************************************/ | |
465 void | |
466 gaim_marshal_VOID(GaimCallback cb, va_list args, void *data, | |
467 void **return_val) | |
468 { | |
469 ((void (*)(void *))cb)(data); | |
470 } | |
471 | |
472 void | |
473 gaim_marshal_VOID__POINTER(GaimCallback cb, va_list args, void *data, | |
474 void **return_val) | |
475 { | |
6505 | 476 void *arg1 = va_arg(args, void *); |
477 | |
478 ((void (*)(void *, void *))cb)(arg1, data); | |
6485 | 479 } |
480 | |
481 void | |
482 gaim_marshal_VOID__POINTER_POINTER(GaimCallback cb, va_list args, | |
483 void *data, void **return_val) | |
484 { | |
6505 | 485 void *arg1 = va_arg(args, void *); |
486 void *arg2 = va_arg(args, void *); | |
487 | |
488 ((void (*)(void *, void *, void *))cb)(arg1, arg2, data); | |
6485 | 489 } |
490 | |
491 void | |
492 gaim_marshal_VOID__POINTER_POINTER_UINT(GaimCallback cb, va_list args, | |
493 void *data, void **return_val) | |
494 { | |
6505 | 495 void *arg1 = va_arg(args, void *); |
496 void *arg2 = va_arg(args, void *); | |
497 guint arg3 = va_arg(args, guint); | |
498 | |
499 ((void (*)(void *, void *, guint, void *))cb)(arg1, arg2, arg3, data); | |
6485 | 500 } |
501 | |
502 void | |
503 gaim_marshal_VOID__POINTER_POINTER_POINTER(GaimCallback cb, va_list args, | |
504 void *data, void **return_val) | |
505 { | |
6505 | 506 void *arg1 = va_arg(args, void *); |
507 void *arg2 = va_arg(args, void *); | |
508 void *arg3 = va_arg(args, void *); | |
509 | |
510 ((void (*)(void *, void *, void *, void *))cb)(arg1, arg2, arg3, data); | |
6485 | 511 } |
512 | |
513 void | |
514 gaim_marshal_VOID__POINTER_POINTER_POINTER_POINTER(GaimCallback cb, | |
515 va_list args, | |
516 void *data, | |
517 void **return_val) | |
518 { | |
6505 | 519 void *arg1 = va_arg(args, void *); |
520 void *arg2 = va_arg(args, void *); | |
521 void *arg3 = va_arg(args, void *); | |
522 void *arg4 = va_arg(args, void *); | |
523 | |
524 ((void (*)(void *, void *, void *, void *, void *))cb)(arg1, arg2, arg3, arg4, data); | |
6485 | 525 } |
6509 | 526 |
527 void | |
528 gaim_marshal_VOID__POINTER_POINTER_POINTER_UINT(GaimCallback cb, | |
529 va_list args, | |
530 void *data, | |
531 void **return_val) | |
532 { | |
533 void *arg1 = va_arg(args, void *); | |
534 void *arg2 = va_arg(args, void *); | |
535 void *arg3 = va_arg(args, void *); | |
536 guint arg4 = va_arg(args, guint); | |
537 | |
538 ((void (*)(void *, void *, void *, guint, void *))cb)(arg1, arg2, arg3, arg4, data); | |
539 } | |
540 | |
6485 | 541 void |
542 gaim_marshal_VOID__POINTER_POINTER_POINTER_UINT_UINT(GaimCallback cb, | |
543 va_list args, | |
544 void *data, | |
545 void **return_val) | |
546 { | |
6505 | 547 void *arg1 = va_arg(args, void *); |
548 void *arg2 = va_arg(args, void *); | |
549 void *arg3 = va_arg(args, void *); | |
550 guint arg4 = va_arg(args, guint); | |
551 guint arg5 = va_arg(args, guint); | |
552 | |
6485 | 553 ((void (*)(void *, void *, void *, guint, guint, void *))cb)( |
6505 | 554 arg1, arg2, arg3, arg4, arg5, data); |
6485 | 555 } |
556 | |
557 void | |
558 gaim_marshal_BOOLEAN__POINTER(GaimCallback cb, va_list args, void *data, | |
559 void **return_val) | |
560 { | |
561 gboolean ret_val; | |
6505 | 562 void *arg1 = va_arg(args, void *); |
6485 | 563 |
6505 | 564 ret_val = ((gboolean (*)(void *, void *))cb)(arg1, data); |
6485 | 565 |
566 if (return_val != NULL) | |
567 *return_val = GINT_TO_POINTER(ret_val); | |
568 } | |
569 | |
570 void | |
571 gaim_marshal_BOOLEAN__POINTER_POINTER(GaimCallback cb, va_list args, | |
572 void *data, void **return_val) | |
573 { | |
574 gboolean ret_val; | |
6505 | 575 void *arg1 = va_arg(args, void *); |
576 void *arg2 = va_arg(args, void *); | |
6485 | 577 |
6505 | 578 ret_val = ((gboolean (*)(void *, void *, void *))cb)(arg1, arg2, data); |
6485 | 579 |
580 if (return_val != NULL) | |
581 *return_val = GINT_TO_POINTER(ret_val); | |
582 } | |
583 | |
584 void | |
6509 | 585 gaim_marshal_BOOLEAN__POINTER_POINTER_POINTER(GaimCallback cb, va_list args, |
586 void *data, void **return_val) | |
587 { | |
588 gboolean ret_val; | |
589 void *arg1 = va_arg(args, void *); | |
590 void *arg2 = va_arg(args, void *); | |
591 void *arg3 = va_arg(args, void *); | |
592 | |
593 ret_val = ((gboolean (*)(void *, void *, void *, void *))cb)(arg1, arg2, | |
594 arg3, data); | |
595 | |
596 if (return_val != NULL) | |
597 *return_val = GINT_TO_POINTER(ret_val); | |
598 } | |
599 | |
600 void | |
601 gaim_marshal_BOOLEAN__POINTER_POINTER_UINT(GaimCallback cb, | |
602 va_list args, | |
603 void *data, | |
604 void **return_val) | |
605 { | |
606 gboolean ret_val; | |
607 void *arg1 = va_arg(args, void *); | |
608 void *arg2 = va_arg(args, void *); | |
609 guint arg3 = va_arg(args, guint); | |
610 | |
611 ret_val = ((gboolean (*)(void *, void *, guint, void *))cb)( | |
612 arg1, arg2, arg3, data); | |
613 | |
614 if (return_val != NULL) | |
615 *return_val = GINT_TO_POINTER(ret_val); | |
616 } | |
617 | |
618 void | |
6485 | 619 gaim_marshal_BOOLEAN__POINTER_POINTER_POINTER_UINT(GaimCallback cb, |
620 va_list args, | |
621 void *data, | |
622 void **return_val) | |
623 { | |
624 gboolean ret_val; | |
6505 | 625 void *arg1 = va_arg(args, void *); |
626 void *arg2 = va_arg(args, void *); | |
627 void *arg3 = va_arg(args, void *); | |
628 guint arg4 = va_arg(args, guint); | |
6485 | 629 |
630 ret_val = ((gboolean (*)(void *, void *, void *, guint, void *))cb)( | |
6505 | 631 arg1, arg2, arg3, arg4, data); |
6485 | 632 |
633 if (return_val != NULL) | |
634 *return_val = GINT_TO_POINTER(ret_val); | |
635 } | |
636 | |
637 void | |
638 gaim_marshal_BOOLEAN__POINTER_POINTER_POINTER_POINTER(GaimCallback cb, | |
639 va_list args, | |
640 void *data, | |
641 void **return_val) | |
642 { | |
643 gboolean ret_val; | |
6505 | 644 void *arg1 = va_arg(args, void *); |
645 void *arg2 = va_arg(args, void *); | |
646 void *arg3 = va_arg(args, void *); | |
647 void *arg4 = va_arg(args, void *); | |
6485 | 648 |
649 ret_val = ((gboolean (*)(void *, void *, void *, void *, void *))cb)( | |
6505 | 650 arg1, arg2, arg3, arg4, data); |
6485 | 651 |
652 if (return_val != NULL) | |
653 *return_val = GINT_TO_POINTER(ret_val); | |
654 } | |
655 | |
656 void | |
657 gaim_marshal_BOOLEAN__POINTER_POINTER_POINTER_POINTER_POINTER( | |
658 GaimCallback cb, va_list args, void *data, void **return_val) | |
659 { | |
660 gboolean ret_val; | |
6505 | 661 void *arg1 = va_arg(args, void *); |
662 void *arg2 = va_arg(args, void *); | |
663 void *arg3 = va_arg(args, void *); | |
664 void *arg4 = va_arg(args, void *); | |
665 void *arg5 = va_arg(args, void *); | |
6485 | 666 |
667 ret_val = | |
668 ((gboolean (*)(void *, void *, void *, void *, void *, void *))cb)( | |
6505 | 669 arg1, arg2, arg3, arg4, arg5, data); |
6485 | 670 |
671 if (return_val != NULL) | |
672 *return_val = GINT_TO_POINTER(ret_val); | |
673 } |