annotate log.c @ 8:ec800a5fb7e3

scid: advertise -s option
author David Demelier <markand@malikania.fr>
date Wed, 23 Jun 2021 11:45:07 +0200
parents f1de39079243
children 3051ef92173a
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
1 /*
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
2 * log.c -- logging routines
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
3 *
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
4 * Copyright (c) 2020-2021 David Demelier <markand@malikania.fr>
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
5 *
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
6 * Permission to use, copy, modify, and/or distribute this software for any
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
7 * purpose with or without fee is hereby granted, provided that the above
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
8 * copyright notice and this permission notice appear in all copies.
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
9 *
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
10 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
11 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
12 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
13 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
14 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
15 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
16 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
17 */
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
18
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
19 #include <assert.h>
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
20 #include <stdio.h>
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
21 #include <syslog.h>
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
22
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
23 #include "log.h"
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
24
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
25 /* TODO: replace. */
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
26 static struct {
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
27 enum log_level verbosity;
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
28 } config = {
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
29 .verbosity = LOG_LEVEL_DEBUG
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
30 };
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
31
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
32 static int syslog_levels[] = {
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
33 [LOG_LEVEL_DEBUG] = LOG_DEBUG,
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
34 [LOG_LEVEL_INFO] = LOG_INFO,
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
35 [LOG_LEVEL_WARNING] = LOG_WARNING
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
36 };
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
37
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
38 void
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
39 log_open(const char *name)
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
40 {
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
41 openlog(name, 0, LOG_USER);
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
42 }
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
43
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
44 void
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
45 log_write(enum log_level level, const char *fmt, ...)
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
46 {
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
47 assert(level >= LOG_LEVEL_WARNING && level <= LOG_LEVEL_DEBUG);
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
48 assert(fmt);
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
49
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
50 if (config.verbosity >= level) {
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
51 va_list ap;
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
52
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
53 va_start(ap, fmt);
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
54 log_vwrite(level, fmt, ap);
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
55 va_end(ap);
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
56 }
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
57 }
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
58
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
59 void
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
60 log_vwrite(enum log_level level, const char *fmt, va_list ap)
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
61 {
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
62 assert(level >= LOG_LEVEL_WARNING && level <= LOG_LEVEL_DEBUG);
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
63 assert(fmt);
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
64
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
65 char line[BUFSIZ];
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
66
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
67 vsnprintf(line, sizeof (line), fmt, ap);
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
68 syslog(syslog_levels[level], "%s", line);
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
69 }
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
70
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
71 void
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
72 log_finish(void)
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
73 {
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
74 if (config.verbosity > 0)
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
75 closelog();
f1de39079243 misc: initial import
David Demelier <markand@malikania.fr>
parents:
diff changeset
76 }