aboutsummaryrefslogtreecommitdiffstats
path: root/camel/camel-object.c
diff options
context:
space:
mode:
Diffstat (limited to 'camel/camel-object.c')
-rw-r--r--camel/camel-object.c20
1 files changed, 12 insertions, 8 deletions
diff --git a/camel/camel-object.c b/camel/camel-object.c
index 5e7eac7504..6e3b5ef54b 100644
--- a/camel/camel-object.c
+++ b/camel/camel-object.c
@@ -694,15 +694,16 @@ static CamelHookList *camel_object_get_hooks(CamelObject *o)
#endif
unsigned int
-camel_object_hook_event(CamelObject * obj, const char * name, CamelObjectEventHookFunc func, void *data)
+camel_object_hook_event(void *vo, const char * name, CamelObjectEventHookFunc func, void *data)
{
+ CamelObject *obj = vo;
CamelHookPair *pair, *hook;
CamelHookList *hooks;
int id;
- g_return_val_if_fail (CAMEL_IS_OBJECT (obj), 0);
- g_return_val_if_fail (name != NULL, 0);
- g_return_val_if_fail (func != NULL, 0);
+ g_return_val_if_fail(CAMEL_IS_OBJECT (obj), 0);
+ g_return_val_if_fail(name != NULL, 0);
+ g_return_val_if_fail(func != NULL, 0);
hook = obj->klass->hooks;
while (hook) {
@@ -736,8 +737,9 @@ setup:
}
void
-camel_object_remove_event(CamelObject * obj, unsigned int id)
+camel_object_remove_event(void *vo, unsigned int id)
{
+ CamelObject *obj = vo;
CamelHookList *hooks;
CamelHookPair *pair, *parent;
@@ -778,8 +780,9 @@ camel_object_remove_event(CamelObject * obj, unsigned int id)
}
void
-camel_object_unhook_event(CamelObject * obj, const char * name, CamelObjectEventHookFunc func, void *data)
+camel_object_unhook_event(void *vo, const char * name, CamelObjectEventHookFunc func, void *data)
{
+ CamelObject *obj = vo;
CamelHookList *hooks;
CamelHookPair *pair, *parent;
@@ -823,8 +826,9 @@ camel_object_unhook_event(CamelObject * obj, const char * name, CamelObjectEvent
}
void
-camel_object_trigger_event (CamelObject * obj, const char * name, void *event_data)
+camel_object_trigger_event(void *vo, const char * name, void *event_data)
{
+ CamelObject *obj = vo;
CamelHookList *hooks;
CamelHookPair *pair, **pairs, *parent, *hook;
int i, size;
@@ -872,7 +876,7 @@ trigger:
}
/* now execute the events we have, if they haven't been removed during our calls */
- for (i=0;i<size;i++) {
+ for (i=size-1;i>=0;i--) {
pair = pairs[i];
if ((pair->flags & CAMEL_HOOK_PAIR_REMOVED) == 0)
(pair->func.event) (obj, event_data, pair->data);