summaryrefslogtreecommitdiffstats
path: root/util/log.h
blob: 15107a5492b749711ffa1c8e18a26b79ab7e2880 (plain)
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
/*
 * Copyright (c) 2021 Martin Wilck, SUSE LLC
 * SPDX-License-Identifier: LGPL-2.1-or-newer
 */
#ifndef _LOG_H
#define _LOG_H

#ifndef MAX_LOGLEVEL
#  define MAX_LOGLEVEL LOG_DEBUG
#endif
#ifndef DEFAULT_LOGLEVEL
#  define DEFAULT_LOGLEVEL LOG_NOTICE
#endif

#if (LOG_FUNCNAME == 1)
#define _log_func __func__
#else
#define _log_func NULL
#endif

extern int log_level;
extern bool log_timestamp;
extern bool log_pid;

void __attribute__((format(printf, 3, 4)))
__msg(int lvl, const char *func, const char *format, ...);

#define msg(lvl, format, ...)						\
	do {								\
		if ((lvl) <= MAX_LOGLEVEL)				\
			__msg(lvl, _log_func, format, ##__VA_ARGS__);	\
	} while (0)

#endif /* _LOG_H */