annotate log.c @ 25:f4e8a7920b94

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