Mercurial > molko
annotate libmlk-core/mlk/core/panic.h @ 646:7e1eb7f6c049 default tip @
misc: remove .clang
author | David Demelier <markand@malikania.fr> |
---|---|
date | Sun, 04 Feb 2024 15:24:37 +0100 |
parents | 75944708c55c |
children |
rev | line source |
---|---|
88
44de3c528b63
core: implement basic panic mechanism, continue #2484 @1h
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
1 /* |
44de3c528b63
core: implement basic panic mechanism, continue #2484 @1h
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
2 * panic.h -- unrecoverable error handling |
44de3c528b63
core: implement basic panic mechanism, continue #2484 @1h
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> |
88
44de3c528b63
core: implement basic panic mechanism, continue #2484 @1h
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
5 * |
44de3c528b63
core: implement basic panic mechanism, continue #2484 @1h
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
6 * Permission to use, copy, modify, and/or distribute this software for any |
44de3c528b63
core: implement basic panic mechanism, continue #2484 @1h
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
7 * purpose with or without fee is hereby granted, provided that the above |
44de3c528b63
core: implement basic panic mechanism, continue #2484 @1h
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
8 * copyright notice and this permission notice appear in all copies. |
44de3c528b63
core: implement basic panic mechanism, continue #2484 @1h
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
9 * |
44de3c528b63
core: implement basic panic mechanism, continue #2484 @1h
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
10 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES |
44de3c528b63
core: implement basic panic mechanism, continue #2484 @1h
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
11 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF |
44de3c528b63
core: implement basic panic mechanism, continue #2484 @1h
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
12 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR |
44de3c528b63
core: implement basic panic mechanism, continue #2484 @1h
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
13 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES |
44de3c528b63
core: implement basic panic mechanism, continue #2484 @1h
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
14 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN |
44de3c528b63
core: implement basic panic mechanism, continue #2484 @1h
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
15 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF |
44de3c528b63
core: implement basic panic mechanism, continue #2484 @1h
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
16 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. |
44de3c528b63
core: implement basic panic mechanism, continue #2484 @1h
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
17 */ |
44de3c528b63
core: implement basic panic mechanism, continue #2484 @1h
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
18 |
366
19782ea1cf4a
misc: start rebranding
David Demelier <markand@malikania.fr>
parents:
348
diff
changeset
|
19 #ifndef MLK_CORE_PANIC_H |
19782ea1cf4a
misc: start rebranding
David Demelier <markand@malikania.fr>
parents:
348
diff
changeset
|
20 #define MLK_CORE_PANIC_H |
88
44de3c528b63
core: implement basic panic mechanism, continue #2484 @1h
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
21 |
548
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
22 /** |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
23 * \file panic.h |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
24 * \brief Unrecoverable error handling |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
25 * |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
26 * This module is intended to be used whenever an unrecoverable error happens |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
27 * and the action is left to the developer. |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
28 * |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
29 * Most of the API don't call panic directly. |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
30 */ |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
31 |
253
c4da052c0def
core: goodbye doxygen
David Demelier <markand@malikania.fr>
parents:
243
diff
changeset
|
32 #include <stdarg.h> |
88
44de3c528b63
core: implement basic panic mechanism, continue #2484 @1h
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
33 |
548
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
34 /** |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
35 * Maximum trace line |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
36 */ |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
37 #define PANIC_LINE_MAX (128) |
486 | 38 |
548
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
39 /** |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
40 * Default panic handler. |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
41 * |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
42 * The default handler prints the line and exit using C [abort]. |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
43 * |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
44 * [abort]: https://en.cppreference.com/w/c/program/abort |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
45 * |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
46 * \param line the line to print |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
47 */ |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
48 extern void (*mlk_panic_handler)(const char *line); |
88
44de3c528b63
core: implement basic panic mechanism, continue #2484 @1h
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
49 |
517
6e8f6640e05b
misc: use extern C manually
David Demelier <markand@malikania.fr>
parents:
486
diff
changeset
|
50 #if defined(__cplusplus) |
6e8f6640e05b
misc: use extern C manually
David Demelier <markand@malikania.fr>
parents:
486
diff
changeset
|
51 extern "C" { |
6e8f6640e05b
misc: use extern C manually
David Demelier <markand@malikania.fr>
parents:
486
diff
changeset
|
52 #endif |
292
08ab73b32832
misc: add extern "C" {} blocks for C++ friends
David Demelier <markand@malikania.fr>
parents:
253
diff
changeset
|
53 |
548
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
54 /** |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
55 * Panic the game with using a [printf] format style message |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
56 * |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
57 * [printf]: https://en.cppreference.com/w/c/io/fprintf |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
58 * |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
59 * \pre fmt != NULL |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
60 * \param fmt the printf format string |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
61 */ |
348
7d7991f97acf
misc: be more barebone portable
David Demelier <markand@malikania.fr>
parents:
320
diff
changeset
|
62 void |
465
01f5580e43d1
core: panic -> mlk_panic
David Demelier <markand@malikania.fr>
parents:
462
diff
changeset
|
63 mlk_panicf(const char *, ...); |
88
44de3c528b63
core: implement basic panic mechanism, continue #2484 @1h
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
64 |
548
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
65 /** |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
66 * Similar to ::mlk_panicf but using a `va_list` instead. |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
67 * |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
68 * \pre fmt != NULL |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
69 * \param fmt the printf format string |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
70 * \param ap the variadic handle |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
71 */ |
348
7d7991f97acf
misc: be more barebone portable
David Demelier <markand@malikania.fr>
parents:
320
diff
changeset
|
72 void |
465
01f5580e43d1
core: panic -> mlk_panic
David Demelier <markand@malikania.fr>
parents:
462
diff
changeset
|
73 mlk_panicva(const char *, va_list); |
95
e82eca4f8606
core: simplify error/panic routines
David Demelier <markand@malikania.fr>
parents:
88
diff
changeset
|
74 |
548
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
75 /** |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
76 * Similar to ::mlk_panicf but uses ::mlk_err to retrieve the last error as the |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
77 * final message. |
75944708c55c
core: doxygenize panic
David Demelier <markand@malikania.fr>
parents:
547
diff
changeset
|
78 */ |
348
7d7991f97acf
misc: be more barebone portable
David Demelier <markand@malikania.fr>
parents:
320
diff
changeset
|
79 void |
547
c7664b679a95
misc: remove error codes for now
David Demelier <markand@malikania.fr>
parents:
517
diff
changeset
|
80 mlk_panic(void); |
88
44de3c528b63
core: implement basic panic mechanism, continue #2484 @1h
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
81 |
517
6e8f6640e05b
misc: use extern C manually
David Demelier <markand@malikania.fr>
parents:
486
diff
changeset
|
82 #if defined(__cplusplus) |
6e8f6640e05b
misc: use extern C manually
David Demelier <markand@malikania.fr>
parents:
486
diff
changeset
|
83 } |
6e8f6640e05b
misc: use extern C manually
David Demelier <markand@malikania.fr>
parents:
486
diff
changeset
|
84 #endif |
292
08ab73b32832
misc: add extern "C" {} blocks for C++ friends
David Demelier <markand@malikania.fr>
parents:
253
diff
changeset
|
85 |
366
19782ea1cf4a
misc: start rebranding
David Demelier <markand@malikania.fr>
parents:
348
diff
changeset
|
86 #endif /* !MLK_CORE_PANIC_H */ |