X-Git-Url: http://git.pk910.de/?a=blobdiff_plain;f=src%2FIRCEvents.c;h=9e0222bcbb1afaabc915d63045ae40a3d30acd7b;hb=706e48b1e666054030c491d864f740071e390038;hp=eb29a094ff23f8c3ea238b1c3ea81c488afb1d5f;hpb=b53d0c5f88063f075a48a0426f9d5d6b3490b9fc;p=NeonServV5.git diff --git a/src/IRCEvents.c b/src/IRCEvents.c index eb29a09..9e0222b 100644 --- a/src/IRCEvents.c +++ b/src/IRCEvents.c @@ -24,6 +24,7 @@ struct binding { void *func; + int module_id; struct binding *next; }; @@ -66,6 +67,25 @@ void free_bind() { free(binds); } +void unregister_module_events(int module_id) { + struct binding *cbind, *next, *prev; + int i; + for(i = 0; i < TOTAL_BIND_TYPES; i++) { + prev = NULL; + for(cbind = binds[i]; cbind; cbind = next) { + next = cbind->next; + if(cbind->module_id == module_id) { + if(prev) + prev->next = next; + else + binds[i] = next; + free(cbind); + } else + prev = cbind; + } + } +} + static int is_bound(unsigned char type, void *func) { struct binding *cbind; for(cbind = binds[type]; cbind; cbind = cbind->next) { @@ -76,7 +96,7 @@ static int is_bound(unsigned char type, void *func) { } #define FUNC_BIND(NAME,FUNCTYPE,TYPE) \ -int bind_##NAME(FUNCTYPE *func) { \ +int bind_##NAME(FUNCTYPE *func, int module_id) { \ if(!is_bound(TYPE, func)) { \ struct binding *cbind = malloc(sizeof(*cbind)); \ if (!cbind) { \ @@ -84,6 +104,7 @@ int bind_##NAME(FUNCTYPE *func) { \ return 0; \ } \ cbind->func = func; \ + cbind->module_id = module_id \ cbind->next = binds[TYPE]; \ binds[TYPE] = cbind; \ return 1; \