[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[or-cvs] the logs now include a timestamp and severity



Update of /home/or/cvsroot/src/common
In directory moria.seul.org:/home/arma/work/onion/cvs/src/common

Modified Files:
	log.c 
Log Message:
the logs now include a timestamp and severity

the implementation is sort of a kludge..you're welcome to fix it up


Index: log.c
===================================================================
RCS file: /home/or/cvsroot/src/common/log.c,v
retrieving revision 1.2
retrieving revision 1.3
diff -u -d -r1.2 -r1.3
--- log.c	12 Jul 2002 18:14:16 -0000	1.2
+++ log.c	4 Sep 2002 00:39:33 -0000	1.3
@@ -8,6 +8,11 @@
 /*
  * Changes :
  * $Log$
+ * Revision 1.3  2002/09/04 00:39:33  arma
+ * the logs now include a timestamp and severity
+ *
+ * the implementation is sort of a kludge..you're welcome to fix it up
+ *
  * Revision 1.2  2002/07/12 18:14:16  montrose
  * removed loglevel from global namespace. severity level is set using log() with a NULL format argument now. example: log(LOG_ERR,NULL);
  *
@@ -55,12 +60,53 @@
 #include <syslog.h>
 #include <string.h>
 #include <errno.h>
+#include <assert.h>
+#include <time.h>
 #include "log.h"
 
+/* FIXME this whole thing is hacked together. feel free to make it clean. */
+size_t sev_to_string(char *buf, int max, int severity) {
+  assert(max > 20);
+
+  switch(severity) {
+    case LOG_DEBUG:
+      strcpy(buf,"debug");  
+      break;
+    case LOG_INFO:
+      strcpy(buf,"info");
+      break;
+    case LOG_NOTICE:
+      strcpy(buf,"notice");
+      break;
+    case LOG_WARNING:
+      strcpy(buf,"warn");
+      break;
+    case LOG_ERR:
+      strcpy(buf,"err");
+      break;
+    case LOG_CRIT:
+      strcpy(buf,"crit");
+      break;
+    case LOG_ALERT:
+      strcpy(buf,"alert");
+      break;
+    case LOG_EMERG: 
+      strcpy(buf,"emerg");
+      break;
+    default:
+      strcpy(buf,"UNKNOWN");
+      break;
+  }
+
+  return strlen(buf)+1;
+}
+
 /* Outputs a message to stdout */
 void log(int severity, const char *format, ...)
 {
   static int loglevel = LOG_DEBUG;
+  char buf[201];
+  time_t t;
   va_list ap;
 
   if ( format )
@@ -70,6 +116,11 @@
   
     if (severity <= loglevel)
     {
+      t = time(NULL);
+      strftime(buf, 200, "%b %d %H:%M:%S", localtime(&t));
+      printf("%s ", buf);
+      sev_to_string(buf, 200, severity);
+      printf("[%s] ", buf);
       vprintf(format,ap);
       printf("\n");
     }
@@ -79,3 +130,4 @@
   else
     loglevel = severity;
 }
+