Definition in file error.c.
#include <pthread.h>
#include "lib/error.h"

Go to the source code of this file.
Classes | |
| struct | lumiera_errorcontext_struct |
| Holding error and some context data. More... | |
Typedefs | |
|
typedef struct lumiera_errorcontext_struct | lumiera_errorcontext |
| typedef lumiera_errorcontext * | LumieraErrorcontext |
Functions | |
| lumiera_err | lumiera_error (void) |
| Get and clear current error state. | |
| LUMIERA_ERROR_DEFINE (UNKNOWN,"unknown error") | |
| LUMIERA_ERROR_DEFINE (EERROR,"could not initialize error system") | |
| LUMIERA_ERROR_DEFINE (ERRNO,"errno") | |
| int | lumiera_error_expect (lumiera_err expected) |
| Expect some error Check that the current error state matches some expectation, if true then the error state is cleared and 1 is returned, otherwise 0 is returned and the error state remains set. | |
| const char * | lumiera_error_extra (void) |
| Query the extra context for the last error. | |
| LumieraErrorcontext | lumiera_error_get (void) |
| lumiera_err | lumiera_error_peek (void) |
| Check current error state without clearing it Please avoid this function and use lumiera_error() if possible. | |
| lumiera_err | lumiera_error_set (lumiera_err nerr, const char *extra) |
| Set error state for the current thread. | |
| static void | lumiera_error_tls_delete (void *err) |
| static void | lumiera_error_tls_init (void) |
Variables | |
| static pthread_once_t | lumiera_error_initialized = PTHREAD_ONCE_INIT |
| static pthread_key_t | lumiera_error_tls |
| lumiera_err lumiera_error_set | ( | lumiera_err | nerr, | |
| const char * | extra | |||
| ) |
Set error state for the current thread.
If the error state of the current thread was cleared, then set it, else preserve the old state.
| nerr | name of the error with 'LUMIERA_ERROR_' prefix (example: LUMIERA_ERROR_NO_MEMORY) | |
| extra | a string (possibly a constructed tmpbuf) which adds some more context to the error, can be a temporary |
| lumiera_err lumiera_error | ( | void | ) |
Get and clear current error state.
This function clears the error state, if it needs to be reused, one has to store it in a temporary variable.
Definition at line 115 of file error.c.
Referenced by test::Suite::describe(), control::HandlingPattern::invoke(), mobject::session::PlacementIndex::isValid(), lib::advice::Index< POA >::isValid(), lumiera_plugin_init(), lumiera::maybeThrow(), lib::advice::Provision< AD >::storeCopy(), and lumiera::throwOnError().

| const char* lumiera_error_extra | ( | void | ) |
Query the extra context for the last error.
Definition at line 126 of file error.c.
References lumiera_errorcontext_struct::extra.
| lumiera_err lumiera_error_peek | ( | void | ) |
Check current error state without clearing it Please avoid this function and use lumiera_error() if possible.
Errors must be cleared else certain parts of the application refuse to cooperate with you. This shall only be used to decide if one wants to barf out of a loop or subroutine to deliver the error to a higher level.
Definition at line 133 of file error.c.
References lumiera_errorcontext_struct::err.
Referenced by lumiera_plugin_discover(), and lumiera_plugin_register().

| int lumiera_error_expect | ( | lumiera_err | expected | ) |
Expect some error Check that the current error state matches some expectation, if true then the error state is cleared and 1 is returned, otherwise 0 is returned and the error state remains set.
| expected | error which is expected |
1.5.6