fujuntang
2021-11-30 490948a0d52a3ad7b3f94525a982fc7012d06011
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
#ifndef __LOGGER_H__
#define __LOGGER_H__
 
#include "usg_common.h"
#include "usg_typedef.h"
 
struct LoggerConfig {
  std::string logFile;
  int level; 
  bool console;
};
 
class Logger {
private:
  std::string configFile;
  LoggerConfig config;
  FILE *logFile;
 
  void dolog(const char *fmt, va_list ap, int level, int err = 0);
 
  
  void init();
 
private:
  static const char *LOGGER_LEVEL_STR[] ;
public:
  enum LoggerLevel { ALL, DEBUG, INFO, WARN, ERROR, FATAL, OFF };
 
 
  Logger(int l = INFO);
  Logger(std::string cf);
  Logger(LoggerConfig & conf);
 
  ~Logger();
 
  void log(int _level, const char *fmt, ...);
 
  void debug(const char *fmt, ...);
  void info(const char *fmt, ...);
  void warn(const char *fmt, ...);
  void error(const char *fmt, ...);
  void error(int err, const char *fmt, ...);
  void fatal(const char *fmt, ...);
  void fatal(int err, const char *fmt, ...) ;
 
  static const char * strlevel(int level);
};
 
#endif