annotate log.c @ 6:882acedb9b89

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