Error handling
NAME
Error handling - How to handle errors which might very well happen.
Data Structures
struct brlapi_error_t
Defines
#define BRLERR_SUCCESS 0
#define BRLERR_NOMEM 1
#define BRLERR_TTYBUSY 2
#define BRLERR_RAWMODEBUSY 3
#define BRLERR_UNKNOWN_INSTRUCTION 4
#define BRLERR_ILLEGAL_INSTRUCTION 5
#define BRLERR_INVALID_PARAMETER 6
#define BRLERR_INVALID_PACKET 7
#define BRLERR_CONNREFUSED 8
#define BRLERR_OPNOTSUPP 9
#define BRLERR_GAIERR 10
#define BRLERR_LIBCERR 11
#define BRLERR_UNKNOWNTTY 12
#define BRLERR_PROTOCOL_VERSION 13
#define BRLERR_EOF 14
#define BRLERR_EMPTYKEY 15
#define BRLERR_DRIVERERROR 16
#define brlapi_error (*brlapi_error_location())
#define brlapi_errno (brlapi_error.brlerrno)
#define brlapi_libcerrno (brlapi_error.exterrno.libcerrno)
#define brlapi_gaierrno (brlapi_error.exterrno.gaierrno)
#define brlapi_errfun (brlapi_error.errfun)
Typedefs
typedef uint32_t brl_type_t
typedef void(* brlapi_exceptionHandler_t )(int err, brl_type_t type, const void *buf, size_t size)
Functions
void brlapi_perror (const char *s)
brlapi_error_t * brlapi_error_location (void)
const char * brlapi_strerror (const brlapi_error_t *error)
const char * brlapi_packetType (brl_type_t ptype)
int brlapi_strexception (char *buf, size_t n, int err, brl_type_t type, const void *packet, size_t size)
brlapi_exceptionHandler_t brlapi_setExceptionHandler (brlapi_exceptionHandler_t handler)
Variables
const char * brlapi_errlist []
const int brlapi_nerr
brlapi_error_t brlapi_error
int brlapi_errno
int brlapi_libcerrno
int brlapi_gaierrno
const char * brlapi_errfun
Detailed Description
When a function fails for some normal error, brlapi_errno will hold an error code to explain why it failed. It is good practice to print it somewhere for the user or the programmer to understand why it failed.
When something really wrong was done somewhere, like an out-of-bounds argument, which is really a bug in either the implementation of BrlAPI or in the application, an exception may be sent by the server. As soon as libbrlapi receives it, an exception handler prints it and abort()s he program, since it means something went really wrong and that we shouldn't go further.
This is hopefully a really seldom event, but in the case of an editor, for instance, one would surely want to have files saved before actually abort()ing. brlapi_setExceptionHandler() lets the programmer define another exception handler which would save files and then call the default handler brlapi_defaultExceptionHandler().
Define Documentation
#define brlapi_errfun (brlapi_error.errfun)
Cheat about the brlapi_errfun C token
#define brlapi_errno (brlapi_error.brlerrno)
Cheat about the brlapi_errno C token
#define brlapi_error (*brlapi_error_location())
Cheat about the brlapi_error C token
#define brlapi_gaierrno (brlapi_error.exterrno.gaierrno)
Cheat about the brlapi_gaierrno C token
#define brlapi_libcerrno (brlapi_error.exterrno.libcerrno)
Cheat about the brlapi_libcerrno C token
#define BRLERR_CONNREFUSED 8
Connection refused
#define BRLERR_DRIVERERROR 16
Packet returned by driver too large
#define BRLERR_EMPTYKEY 15
Key file empty
#define BRLERR_EOF 14
Unexpected end of file
#define BRLERR_GAIERR 10
Getaddrinfo error
#define BRLERR_ILLEGAL_INSTRUCTION 5
Forbiden in current mode
#define BRLERR_INVALID_PACKET 7
Invalid size
#define BRLERR_INVALID_PARAMETER 6
Out of range or have no sense
#define BRLERR_LIBCERR 11
Libc error
#define BRLERR_NOMEM 1
Not enough memory
#define BRLERR_OPNOTSUPP 9
Operation not supported
#define BRLERR_PROTOCOL_VERSION 13
Bad protocol version
#define BRLERR_RAWMODEBUSY 3
A connection is already using RAW mode
#define BRLERR_SUCCESS 0
Success
#define BRLERR_TTYBUSY 2
A connection is already running in this tty
#define BRLERR_UNKNOWN_INSTRUCTION 4
Not implemented in protocol
#define BRLERR_UNKNOWNTTY 12
Couldn't find out the tty number
Typedef Documentation
typedef uint32_t brl_type_t
Type for packet type. Only unsigned can cross networks, 32bits
typedef void(* brlapi_exceptionHandler_t)(int err, brl_type_t type, const void *buf, size_t size)
Type for error handlers
Type of error handlers which are to be given to brlapi_setExceptionHandler().
Parameters:
err is a BRLERR_ error code;
type is the type of the guilty packet;
buf points to the content of the guilty packet (might be a little bit truncated);
size gives the guilty packet's size.
Function Documentation
brlapi_error_t* brlapi_error_location (void)
Get per-thread error location
In multithreaded software, brlapi_error is thread-specific, so api.h cheats about the brlapi_error token and actually calls brlapi_error_location().
This gets the thread specific location of global variable brlapi_error
const char* brlapi_packetType (brl_type_t ptype)
Get plain packet type
brlapi_packetType() returns the plain packet type name corresponding to its argument.
void brlapi_perror (const char * s)
Print a BrlAPI error message
brlapi_perror() reads brlapi_error, and acts just like perror().
brlapi_exceptionHandler_t brlapi_setExceptionHandler (brlapi_exceptionHandler_t handler)
Set a new exception handler
brlapi_setExceptionHandler() replaces the previous exception handler with the handler parameter. The previous exception handler is returned to make chaining error handlers possible.
The default handler just prints the exception and exit()s.
const char* brlapi_strerror (const brlapi_error_t * error)
Get plain error message
brlapi_strerror() returns the plain error message corresponding to its argument.
int brlapi_strexception (char * buf, size_t n, int err, brl_type_t type, const void * packet, size_t size)
Describes an exception
brlapi_strexception() puts a text describing the given exception in buf.
The beginning of the guilty packet is dumped as a sequence of hex bytes.
Returns:
the size of the text describing the exception, following snprintf()'s semantics.
Variable Documentation
const char* brlapi_errfun
Shorthand for brlapi_error.errfun
const char* brlapi_errlist[]
Error message list
These are the string constants used by
brlapi_perror().
int brlapi_errno
Shorthand for brlapi_error.errno
brlapi_error_t brlapi_error
Global variable brlapi_error
brlapi_error is a global left-value containing the last error information. Its errno field is not reset to BRLERR_SUCCESS on success.
This information may be copied in
brlapi_error_t variables for later use with the brlapi_strerror function.
int brlapi_gaierrno
Shorthand for brlapi_error.exterrno.gaierrno
int brlapi_libcerrno
Shorthand for brlapi_error.exterrno.libcerrno
const int brlapi_nerr
Number of error messages