error.h
2.79 KB
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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
/*
clsync - file tree sync utility based on inotify/kqueue
Copyright (C) 2013-2014 Dmitry Yu Okunev <dyokunev@ut.mephi.ru> 0x8E30679C
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef __CLSYNC_ERROR_H
#define __CLSYNC_ERROR_H
#define BACKTRACE_LENGTH 256
#ifdef _DEBUG_FORCE
# define DEBUGLEVEL_LIMIT 255
#else
# define DEBUGLEVEL_LIMIT 9
#endif
extern void _critical( const char *const function_name, const char *fmt, ...);
#define critical(...) _critical(__FUNCTION__, __VA_ARGS__)
#define critical_on(cond) {debug(30, "critical_on: checking: %s", TOSTR(cond)); if (unlikely(cond)) {critical("Assert: "TOSTR(cond));}}
extern void _error(const char *const function_name, const char *fmt, ...);
#define error(...) _error(__FUNCTION__, __VA_ARGS__)
#define error_on(cond) {if (unlikely(cond)) {error("Error: ("TOSTR(cond)") != 0");}}
extern void _warning(const char *const function_name, const char *fmt, ...);
#define warning(...) _warning(__FUNCTION__, __VA_ARGS__)
extern void _info(const char *const function_name, const char *fmt, ...);
#define info(...) _info(__FUNCTION__, __VA_ARGS__)
#ifdef _DEBUG_SUPPORT
extern void _debug(int debug_level, const char *const function_name, const char *fmt, ...);
# define debug(debug_level, ...) {if (debug_level < DEBUGLEVEL_LIMIT) _debug(debug_level, __FUNCTION__, __VA_ARGS__);}
# define error_or_debug(debug_level, ...) ((debug_level)<0 ? _error(__FUNCTION__, __VA_ARGS__) : _debug(debug_level, __FUNCTION__, __VA_ARGS__))
#else
# define debug(debug_level, ...) {}
# define error_or_debug(debug_level, ...) ((debug_level)<0 ? _error(__FUNCTION__, __VA_ARGS__) : (void)0)
#endif
#define debug_call(debug_level, code) debug(debug_level, "%s -> %i", TOSTR(code), code)
#define critical_or_warning(cond, ...) ((cond) ? _critical : _warning)(__FUNCTION__, __VA_ARGS__)
enum ipc_type {
IPCT_PRIVATE,
IPCT_SHARED,
};
typedef enum ipc_type ipc_type_t;
extern void error_init(void *_outputmethod, int *_quiet, int *_verbose, int *_debug);
extern void error_init_ipc(ipc_type_t ipc_type);
extern void error_deinit();
enum outputmethod {
OM_STDERR = 0,
OM_STDOUT,
OM_SYSLOG,
OM_MAX
};
typedef enum outputmethod outputmethod_t;
#endif