X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=log.c;h=123961202abd5f42faacb0d987779bd612c26d91;hb=9a9fc107975ef7a673856cdf0fda6e157f2227b3;hp=d5669ca6708010a97e14c2e6568e06b021c3c56f;hpb=ea31544cc33afdb355ad524e14c3703b2fe85ce0;p=secnet.git diff --git a/log.c b/log.c index d5669ca..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 && st->f) { - 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); } } @@ -363,6 +359,7 @@ static void logfile_hup_notify(void *sst, int signum) { struct logfile *st=sst; FILE *f; + if (!st->logfile) return; f=fopen(st->logfile,"a"); if (!f) { logfile_log(st,M_FATAL,"received SIGHUP, but could not reopen " @@ -379,7 +376,7 @@ static void logfile_phase_hook(void *sst, uint32_t new_phase) struct logfile *st=sst; FILE *f; - if (background) { + if (background && st->logfile) { f=fopen(st->logfile,"a"); if (!f) fatal_perror("logfile (%s:%d): cannot open \"%s\"", st->loc.file,st->loc.line,st->logfile); @@ -431,7 +428,8 @@ static list_t *logfile_apply(closure_t *self, struct cloc loc, dict_t *context, st->ops.vlogfn=logfile_vlog; st->ops.buff[0]=0; st->loc=loc; - st->f=NULL; + st->f=stderr; + st->prefix=""; st->forked=0; item=list_elem(args,0); @@ -440,7 +438,9 @@ 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",True,"logfile",loc); + 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"); @@ -649,6 +649,8 @@ void log_from_fd(int fd, cstring_t prefix, struct log_if *log) void log_module(dict_t *dict) { + setlinebuf(stderr); + add_closure(dict,"logfile",logfile_apply); add_closure(dict,"syslog",syslog_apply); }