Data Structures | |
struct | DBusError |
Object representing an exception. More... | |
Typedefs | |
typedef DBusError | DBusError |
Mostly-opaque type representing an error that occurred. | |
Functions | |
void | dbus_error_init (DBusError *error) |
Initializes a DBusError structure. | |
void | dbus_error_free (DBusError *error) |
Frees an error that's been set (or just initialized), then reinitializes the error as in dbus_error_init(). | |
void | dbus_set_error_const (DBusError *error, const char *name, const char *message) |
Assigns an error name and message to a DBusError. | |
void | dbus_move_error (DBusError *src, DBusError *dest) |
Moves an error src into dest, freeing src and overwriting dest. | |
dbus_bool_t | dbus_error_has_name (const DBusError *error, const char *name) |
Checks whether the error is set and has the given name. | |
dbus_bool_t | dbus_error_is_set (const DBusError *error) |
Checks whether an error occurred (the error is set). | |
void | dbus_set_error (DBusError *error, const char *name, const char *format,...) |
Assigns an error name and message to a DBusError. |
Types and functions related to reporting errors.
In essence D-Bus error reporting works as follows:
DBusError error; dbus_error_init (&error); dbus_some_function (arg1, arg2, &error); if (dbus_error_is_set (&error)) { fprintf (stderr, "an error occurred: %s\n", error.message); dbus_error_free (&error); }
By convention, all functions allow NULL instead of a DBusError*, so callers who don't care about the error can ignore it.
There are some rules. An error passed to a D-Bus function must always be unset; you can't pass in an error that's already set. If a function has a return code indicating whether an error occurred, and also a DBusError parameter, then the error will always be set if and only if the return code indicates an error occurred. i.e. the return code and the error are never going to disagree.
An error only needs to be freed if it's been set, not if it's merely been initialized.
You can check the specific error that occurred using dbus_error_has_name().
Errors will not be set for programming errors, such as passing invalid arguments to the libdbus API. Instead, libdbus will print warnings, exit on a failed assertion, or even crash in those cases (in other words, incorrect use of the API results in undefined behavior, possibly accompanied by helpful debugging output if you're lucky).
|
Frees an error that's been set (or just initialized), then reinitializes the error as in dbus_error_init().
Definition at line 207 of file dbus-errors.c. References DBusRealError::const_message, dbus_error_init(), dbus_free(), DBusRealError::message, DBusRealError::name, and NULL. Referenced by _dbus_get_local_machine_uuid_encoded(), _dbus_keyring_new_for_credentials(), _dbus_read_uuid_file(), dbus_connection_register_fallback(), dbus_connection_register_object_path(), and dbus_move_error(). |
|
Checks whether the error is set and has the given name.
Definition at line 298 of file dbus-errors.c. References _dbus_assert, _dbus_string_equal(), _dbus_string_init_const(), FALSE, DBusError::message, DBusError::name, and NULL. Referenced by _dbus_read_uuid_file(), dbus_connection_register_fallback(), and dbus_connection_register_object_path(). |
|
Initializes a DBusError structure. Does not allocate any memory; the error only needs to be freed if it is set at some point.
Definition at line 184 of file dbus-errors.c. References _dbus_assert, DBusRealError::const_message, DBusRealError::message, DBusRealError::name, NULL, and TRUE. Referenced by _dbus_keyring_new_for_credentials(), dbus_error_free(), and dbus_move_error(). |
|
Checks whether an error occurred (the error is set).
Definition at line 325 of file dbus-errors.c. References _dbus_assert, FALSE, DBusError::message, DBusError::name, and NULL. Referenced by _dbus_write_pid_to_file_and_pipe(), dbus_address_unescape_value(), and dbus_parse_address(). |
|
Moves an error src into dest, freeing src and overwriting dest. Both src and dest must be initialized. src is reinitialized to an empty error. dest may not contain an existing error. If the destination is NULL, just frees and reinits the source error.
Definition at line 275 of file dbus-errors.c. References dbus_error_free(), and dbus_error_init(). Referenced by _dbus_read_uuid_file(). |
|
|
Assigns an error name and message to a DBusError. Does nothing if error is NULL. The message may be NULL, which means a default message will be deduced from the name. The default message will be totally useless, though, so using a NULL message is not recommended. Because this function does not copy the error name or message, you must ensure the name and message are global data that won't be freed. You probably want dbus_set_error() instead, in most cases.
Definition at line 239 of file dbus-errors.c. References _dbus_assert, DBusRealError::const_message, DBusRealError::message, DBusError::message, DBusRealError::name, DBusError::name, NULL, and TRUE. Referenced by _dbus_keyring_get_best_key(), and _dbus_keyring_new_for_credentials(). |