Mercurial > molko
annotate libmlk-core/mlk/core/trace.c @ 646:7e1eb7f6c049 default tip @
misc: remove .clang
author | David Demelier <markand@malikania.fr> |
---|---|
date | Sun, 04 Feb 2024 15:24:37 +0100 |
parents | 970cad994a95 |
children |
rev | line source |
---|---|
141
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
1 /* |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
2 * trace.h -- non-fatal message logs |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
3 * |
445
773a082f0b91
misc: update copyright years
David Demelier <markand@malikania.fr>
parents:
431
diff
changeset
|
4 * Copyright (c) 2020-2023 David Demelier <markand@malikania.fr> |
141
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
5 * |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
6 * Permission to use, copy, modify, and/or distribute this software for any |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
7 * purpose with or without fee is hereby granted, provided that the above |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
8 * copyright notice and this permission notice appear in all copies. |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
9 * |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
10 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
11 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
12 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
13 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
14 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
15 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
16 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
17 */ |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
18 |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
19 #include <assert.h> |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
20 #include <stdio.h> |
541
970cad994a95
core: doxygenize trace
David Demelier <markand@malikania.fr>
parents:
473
diff
changeset
|
21 #include <time.h> |
141
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
22 |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
23 #include "trace.h" |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
24 |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
25 static void |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
26 default_handler(const char *line) |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
27 { |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
28 assert(line); |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
29 |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
30 puts(line); |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
31 } |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
32 |
473
02b16dd49b54
core: trace -> mlk_trace
David Demelier <markand@malikania.fr>
parents:
445
diff
changeset
|
33 void (*mlk_trace_handler)(const char *) = default_handler; |
141
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
34 |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
35 void |
473
02b16dd49b54
core: trace -> mlk_trace
David Demelier <markand@malikania.fr>
parents:
445
diff
changeset
|
36 mlk_tracef(const char *fmt, ...) |
141
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
37 { |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
38 assert(fmt); |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
39 |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
40 va_list ap; |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
41 |
473
02b16dd49b54
core: trace -> mlk_trace
David Demelier <markand@malikania.fr>
parents:
445
diff
changeset
|
42 if (!mlk_trace_handler) |
141
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
43 return; |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
44 |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
45 va_start(ap, fmt); |
473
02b16dd49b54
core: trace -> mlk_trace
David Demelier <markand@malikania.fr>
parents:
445
diff
changeset
|
46 mlk_traceva(fmt, ap); |
141
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
47 va_end(ap); |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
48 } |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
49 |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
50 void |
473
02b16dd49b54
core: trace -> mlk_trace
David Demelier <markand@malikania.fr>
parents:
445
diff
changeset
|
51 mlk_traceva(const char *fmt, va_list ap) |
141
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
52 { |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
53 assert(fmt); |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
54 |
541
970cad994a95
core: doxygenize trace
David Demelier <markand@malikania.fr>
parents:
473
diff
changeset
|
55 time_t timestamp; |
970cad994a95
core: doxygenize trace
David Demelier <markand@malikania.fr>
parents:
473
diff
changeset
|
56 struct tm *calendar; |
970cad994a95
core: doxygenize trace
David Demelier <markand@malikania.fr>
parents:
473
diff
changeset
|
57 size_t nw; |
970cad994a95
core: doxygenize trace
David Demelier <markand@malikania.fr>
parents:
473
diff
changeset
|
58 char buf[MLK_TRACE_LINE_MAX + 16]; |
141
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
59 |
473
02b16dd49b54
core: trace -> mlk_trace
David Demelier <markand@malikania.fr>
parents:
445
diff
changeset
|
60 if (!mlk_trace_handler) |
141
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
61 return; |
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
62 |
541
970cad994a95
core: doxygenize trace
David Demelier <markand@malikania.fr>
parents:
473
diff
changeset
|
63 /* |
970cad994a95
core: doxygenize trace
David Demelier <markand@malikania.fr>
parents:
473
diff
changeset
|
64 * Append default timestamp so that a line looks like this: |
970cad994a95
core: doxygenize trace
David Demelier <markand@malikania.fr>
parents:
473
diff
changeset
|
65 * |
970cad994a95
core: doxygenize trace
David Demelier <markand@malikania.fr>
parents:
473
diff
changeset
|
66 * 10:10:59: hello world |
970cad994a95
core: doxygenize trace
David Demelier <markand@malikania.fr>
parents:
473
diff
changeset
|
67 */ |
970cad994a95
core: doxygenize trace
David Demelier <markand@malikania.fr>
parents:
473
diff
changeset
|
68 timestamp = time(NULL); |
970cad994a95
core: doxygenize trace
David Demelier <markand@malikania.fr>
parents:
473
diff
changeset
|
69 calendar = localtime(×tamp); |
970cad994a95
core: doxygenize trace
David Demelier <markand@malikania.fr>
parents:
473
diff
changeset
|
70 nw = strftime(buf, sizeof (buf), "%T: ", calendar); |
970cad994a95
core: doxygenize trace
David Demelier <markand@malikania.fr>
parents:
473
diff
changeset
|
71 |
970cad994a95
core: doxygenize trace
David Demelier <markand@malikania.fr>
parents:
473
diff
changeset
|
72 vsnprintf(buf + nw, sizeof (buf) - nw, fmt, ap); |
473
02b16dd49b54
core: trace -> mlk_trace
David Demelier <markand@malikania.fr>
parents:
445
diff
changeset
|
73 mlk_trace_handler(buf); |
141
4eeeccf2b732
core: add trace/vtrace functions, closes #2493
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
74 } |