From f0a889b602a9de1ae15a6acb50dcb94008df3494 Mon Sep 17 00:00:00 2001 From: Valery Yatsko Date: Wed, 2 Apr 2008 02:55:34 +0400 Subject: [PATCH] monitor.{c,h} stuff for libratbox3. --- include/monitor.h | 11 ++-- src/monitor.c | 148 ++++++++++++++++++---------------------------- 2 files changed, 66 insertions(+), 93 deletions(-) diff --git a/include/monitor.h b/include/monitor.h index f052cb3..56974e0 100644 --- a/include/monitor.h +++ b/include/monitor.h @@ -10,6 +10,8 @@ #ifndef INCLUDED_monitor_h #define INCLUDED_monitor_h +struct BlockHeap; + struct monitor { struct monitor *hnext; @@ -17,14 +19,15 @@ struct monitor rb_dlink_list users; }; -extern BlockHeap *monitor_heap; +extern struct monitor *monitorTable[]; + +#define MONITOR_HASH_BITS 16 +#define MONITOR_HASH_SIZE (1<hnext) - { - if(!irccmp(monptr->name, name)) - return monptr; - } - - if(add) - { - monptr = BlockHeapAlloc(monitor_heap); - strlcpy(monptr->name, name, sizeof(monptr->name)); - - monptr->hnext = monitorTable[hashv]; - monitorTable[hashv] = monptr; - - return monptr; - } - + struct monitor *monptr; + + unsigned int hashv = hash_monitor_nick(name); + + for(monptr = monitorTable[hashv]; monptr; monptr = monptr->hnext) + { + if(!irccmp(monptr->name, name)) + return monptr; + } + + if(add) + { + monptr = rb_bh_alloc(monitor_heap); + rb_strlcpy(monptr->name, name, sizeof(monptr->name)); + + monptr->hnext = monitorTable[hashv]; + monitorTable[hashv] = monptr; + + return monptr; + } + return NULL; } +void +free_monitor(struct monitor *monptr) +{ + rb_bh_free(monitor_heap, monptr); +} + /* monitor_signon() * * inputs - client who has just connected @@ -92,16 +95,15 @@ find_monitor(const char *name, int add) void monitor_signon(struct Client *client_p) { - char buf[USERHOST_REPLYLEN]; - struct monitor *monptr = find_monitor(client_p->name, 0); - - /* noones watching this nick */ - if(monptr == NULL) - return; - - rb_snprintf(buf, sizeof(buf), "%s!%s@%s", - client_p->name, client_p->username, client_p->host); - + char buf[USERHOST_REPLYLEN]; + struct monitor *monptr = find_monitor(client_p->name, 0); + + /* noones watching this nick */ + if(monptr == NULL) + return; + + rb_snprintf(buf, sizeof(buf), "%s!%s@%s", client_p->name, client_p->username, client_p->host); + sendto_monitor(monptr, form_str(RPL_MONONLINE), me.name, "*", buf); } @@ -115,62 +117,30 @@ monitor_signon(struct Client *client_p) void monitor_signoff(struct Client *client_p) { - struct monitor *monptr = find_monitor(client_p->name, 0); - - /* noones watching this nick */ - if(monptr == NULL) - return; - - sendto_monitor(monptr, form_str(RPL_MONOFFLINE), me.name, "*", + struct monitor *monptr = find_monitor(client_p->name, 0); + + /* noones watching this nick */ + if(monptr == NULL) + return; + + sendto_monitor(monptr, form_str(RPL_MONOFFLINE), me.name, "*", client_p->name); } void clear_monitor(struct Client *client_p) { - struct monitor *monptr; - rb_dlink_node *ptr, *next_ptr; - - RB_DLINK_FOREACH_SAFE(ptr, next_ptr, client_p->localClient->monitor_list.head) - { - monptr = ptr->data; - - /* we leave the actual entry around with no users, itll be - * cleaned up periodically by cleanup_monitor() --anfl - */ - rb_dlinkFindDestroy(client_p, &monptr->users); - free_rb_dlink_node(ptr); - } - - client_p->localClient->monitor_list.head = client_p->localClient->monitor_list.tail = NULL; + struct monitor *monptr; + rb_dlink_node *ptr, *next_ptr; + + RB_DLINK_FOREACH_SAFE(ptr, next_ptr, client_p->localClient->monitor_list.head) + { + monptr = ptr->data; + + rb_dlinkFindDestroy(client_p, &monptr->users); + rb_free_rb_dlink_node(ptr); + } + + client_p->localClient->monitor_list.head = client_p->localClient->monitor_list.tail = NULL; client_p->localClient->monitor_list.length = 0; } - -static void -cleanup_monitor(void *unused) -{ - struct monitor *last_ptr = NULL; - struct monitor *next_ptr, *ptr; - int i; - - for(i = 0; i < MONITOR_HASH_SIZE; i++) - { - last_ptr = NULL; - for(ptr = monitorTable[i]; ptr; ptr = next_ptr) - { - next_ptr = ptr->hnext; - - if(!rb_dlink_list_length(&ptr->users)) - { - if(last_ptr) - last_ptr->hnext = next_ptr; - else - monitorTable[i] = next_ptr; - - BlockHeapFree(monitor_heap, ptr); - } - else - last_ptr = ptr; - } - } -}