FILE *logfile;
+static corehandler *coreh, *coret;
+
char *sevtostring(int severity) {
switch(severity) {
case ERR_DEBUG:
if (logfile)
fclose(logfile);
- logfile=fopen("newserv.log","a");
+ logfile=fopen("logs/newserv.log","a");
}
void init_logfile() {
- logfile=fopen("newserv.log","a");
+ logfile=fopen("logs/newserv.log","a");
registerhook(HOOK_CORE_SIGUSR1, reopen_logfile);
}
exit(0);
}
}
+
+void handlecore(void) {
+ corehandler *n;
+
+ /* no attempt is made to clean these up */
+ for(n=coreh;coreh;n=coreh->next)
+ (n->fn)(n->arg);
+}
+
+corehandler *registercorehandler(CoreHandlerFn fn, void *arg) {
+ corehandler *c = (corehandler *)malloc(sizeof(corehandler));
+ /* core if we can't allocate!! */
+
+ c->fn = fn;
+ c->arg = arg;
+ c->next = NULL;
+ c->prev = coret;
+ coret = c->prev;
+
+ if(!coreh)
+ coreh = c;
+
+ return c;
+}
+
+void deregistercorehandler(corehandler *c) {
+ if(!c->prev) {
+ coreh = c->next;
+ } else {
+ c->prev->next = c->next;
+ }
+
+ if(!c->next) {
+ coret = c->prev;
+ } else {
+ c->next->prev = c->prev;
+ }
+
+ free(c);
+}
+