X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=log.c;h=123961202abd5f42faacb0d987779bd612c26d91;hb=1b8af2f7f86131a5364f2270865895ea597c591e;hp=67b43350e127bb86de07f994ee0ba854bfebc07e;hpb=7c4bade1c4dc20a01314b82cecad85509655a251;p=secnet.git diff --git a/log.c b/log.c index 67b4335..1239612 100644 --- a/log.c +++ b/log.c @@ -308,6 +308,7 @@ struct logfile { string_t logfile; uint32_t level; FILE *f; + const char *prefix; bool_t forked; }; @@ -330,22 +331,17 @@ static void logfile_vlog(void *sst, int class, const char *message, pidbuf[0]=0; } - if (secnet_is_daemon) { - if (class&st->level) { - t=time(NULL); - tm=localtime(&t); - fprintf(st->f,"%s %2d %02d:%02d:%02d %s", - months[tm->tm_mon],tm->tm_mday,tm->tm_hour,tm->tm_min, - tm->tm_sec, - pidbuf); - vfprintf(st->f,message,args); - fprintf(st->f,"\n"); - fflush(st->f); - } - } else { - if (pidbuf[0]) MessageFallback(class,"%s",pidbuf); - vMessageFallback(class,message,args); - MessageFallback(class,"\n"); + if (class&st->level) { + t=time(NULL); + tm=localtime(&t); + fprintf(st->f,"%s %2d %02d:%02d:%02d %s%s%s", + months[tm->tm_mon],tm->tm_mday,tm->tm_hour,tm->tm_min, + tm->tm_sec, + st->prefix, st->prefix[0] ? " " : "", + pidbuf); + vfprintf(st->f,message,args); + fprintf(st->f,"\n"); + fflush(st->f); } } @@ -433,6 +429,7 @@ static list_t *logfile_apply(closure_t *self, struct cloc loc, dict_t *context, st->ops.buff[0]=0; st->loc=loc; st->f=stderr; + st->prefix=""; st->forked=0; item=list_elem(args,0); @@ -442,6 +439,8 @@ static list_t *logfile_apply(closure_t *self, struct cloc loc, dict_t *context, dict=item->data.dict; st->logfile=dict_read_string(dict,"filename",False,"logfile",loc); + st->prefix=dict_read_string(dict,"prefix",False,"logfile",loc); + if (!st->prefix) st->prefix=""; st->level=string_list_to_word(dict_lookup(dict,"class"), message_class_table,"logfile");