]> arthur.barton.de Git - netdata.git/blob - src/log.h
08f3c4fe3f5cd68911edc92cf2f5140ab1d82e8b
[netdata.git] / src / log.h
1 #include <stdio.h>
2 #include <stdarg.h>
3
4 #ifndef NETDATA_LOG_H
5 #define NETDATA_LOG_H 1
6
7 #define D_WEB_BUFFER            0x00000001
8 #define D_WEB_CLIENT            0x00000002
9 #define D_LISTENER              0x00000004
10 #define D_WEB_DATA              0x00000008
11 #define D_OPTIONS               0x00000010
12 #define D_PROCNETDEV_LOOP   0x00000020
13 #define D_RRD_STATS             0x00000040
14 #define D_WEB_CLIENT_ACCESS     0x00000080
15 #define D_TC_LOOP           0x00000100
16 #define D_DEFLATE           0x00000200
17 #define D_CONFIG            0x00000400
18 #define D_PLUGINSD          0x00000800
19 #define D_CHILDS            0x00001000
20 #define D_EXIT              0x00002000
21 #define D_CHECKS            0x00004000
22 #define D_NFACCT_LOOP           0x00008000
23 #define D_PROCFILE                      0x00010000
24 #define D_RRD_CALLS                     0x00020000
25 #define D_DICTIONARY            0x00040000
26 #define D_MEMORY                        0x00080000
27
28 //#define DEBUG (D_WEB_CLIENT_ACCESS|D_LISTENER|D_RRD_STATS)
29 //#define DEBUG 0xffffffff
30 #define DEBUG (0)
31
32 extern unsigned long long debug_flags;
33
34 extern const char *program_name;
35
36 extern int silent;
37
38 extern int access_fd;
39 extern FILE *stdaccess;
40
41 extern int access_log_syslog;
42 extern int error_log_syslog;
43 extern int output_log_syslog;
44
45 #define debug(type, args...) do { if(unlikely(!silent && (debug_flags & type))) debug_int(__FILE__, __FUNCTION__, __LINE__, ##args); } while(0)
46 #define info(args...)    info_int(__FILE__, __FUNCTION__, __LINE__, ##args)
47 #define infoerr(args...) error_int("INFO", __FILE__, __FUNCTION__, __LINE__, ##args)
48 #define error(args...)   error_int("ERROR", __FILE__, __FUNCTION__, __LINE__, ##args)
49 #define fatal(args...)   fatal_int(__FILE__, __FUNCTION__, __LINE__, ##args)
50
51 extern void log_date(FILE *out);
52 extern void debug_int( const char *file, const char *function, const unsigned long line, const char *fmt, ... );
53 extern void info_int( const char *file, const char *function, const unsigned long line, const char *fmt, ... );
54 extern void error_int( const char *prefix, const char *file, const char *function, const unsigned long line, const char *fmt, ... );
55 extern void fatal_int( const char *file, const char *function, const unsigned long line, const char *fmt, ... ) __attribute__ ((noreturn));
56 extern void log_access( const char *fmt, ... );
57
58 #endif /* NETDATA_LOG_H */