diff options
author | dimitri staessens <dimitri.staessens@ugent.be> | 2017-09-19 16:48:54 +0000 |
---|---|---|
committer | Sander Vrijders <sander.vrijders@ugent.be> | 2017-09-19 16:48:54 +0000 |
commit | acd8235533d63a7e4dd4d1b5bdb17423d4b6fd75 (patch) | |
tree | 195bbf3a1aa1923394410db072f72c0b38aede8c /src/lib/notifier.c | |
parent | c0bbd7e2184f51038ecbaebfa3b21e5c52d35239 (diff) | |
parent | 1dcef3957393c0500b81d93ffacf573e78be9a51 (diff) | |
download | ouroboros-acd8235533d63a7e4dd4d1b5bdb17423d4b6fd75.tar.gz ouroboros-acd8235533d63a7e4dd4d1b5bdb17423d4b6fd75.zip |
Merged in dstaesse/ouroboros/be-dht-async (pull request #598)
ipcpd: Enroll DHT when creating dt connection
Diffstat (limited to 'src/lib/notifier.c')
-rw-r--r-- | src/lib/notifier.c | 13 |
1 files changed, 9 insertions, 4 deletions
diff --git a/src/lib/notifier.c b/src/lib/notifier.c index cfd383d4..5c38cf58 100644 --- a/src/lib/notifier.c +++ b/src/lib/notifier.c @@ -30,6 +30,7 @@ struct listener { struct list_head next; notifier_fn_t callback; + void * obj; }; struct { @@ -72,13 +73,16 @@ void notifier_event(int event, pthread_mutex_lock(¬ifier.lock); - list_for_each(p, ¬ifier.listeners) - list_entry(p, struct listener, next)->callback(event, o); + list_for_each(p, ¬ifier.listeners) { + struct listener * l = list_entry(p, struct listener, next); + l->callback(l->obj, event, o); + } pthread_mutex_unlock(¬ifier.lock); } -int notifier_reg(notifier_fn_t callback) +int notifier_reg(notifier_fn_t callback, + void * obj) { struct listener * l; struct list_head * p; @@ -100,8 +104,9 @@ int notifier_reg(notifier_fn_t callback) } l->callback = callback; + l->obj = obj; - list_add(&l->next, ¬ifier.listeners); + list_add_tail(&l->next, ¬ifier.listeners); pthread_mutex_unlock(¬ifier.lock); |