/* * Copyright 2008 Google Inc. All Rights Reserved. * * Author: md@google.com (Michael Davidson) */ #include <stdarg.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include "logging.h" static FILE *log_fp = NULL; static const char *program = ""; static int debug = 0; void set_log_file(FILE *fp) { log_fp = fp; } void set_program_name(const char *name) { program = name; } void set_debug_level(int level) { debug = level; } void msg(enum msg_type msg_type, int data, const char *fmt, ...) { va_list ap; int err = 0; const char *type = NULL; /* * default is to log to stdout */ if (!log_fp) log_fp = stdout; switch (msg_type) { case MSG_DEBUG: if (data > debug) return; type = "DEBUG"; break; case MSG_INFO: type = "INFO"; break; case MSG_WARN: type = "WARN"; break; case MSG_ERROR: type = "ERROR"; err = data; break; case MSG_FATAL: type = "FATAL"; err = data; break; } va_start(ap, fmt); if (type) fprintf(log_fp, "%s: ", type); if (program) fprintf(log_fp, "%s: ", program); vfprintf(log_fp, fmt, ap); if (err) { fprintf(log_fp, ": %s\n", strerror(err)); } else { fputc('\n', log_fp); } va_end(ap); if (msg_type == MSG_FATAL) exit(EXIT_FAILURE); }