9#ifndef BABELTRACE2_ERROR_REPORTING_H
10#define BABELTRACE2_ERROR_REPORTING_H
12#ifndef __BT_IN_BABELTRACE_H
13# error "Please include <babeltrace2/babeltrace.h> instead."
18#include <babeltrace2/types.h>
19#include <babeltrace2/graph/component-class.h>
493#define BT_CURRENT_THREAD_MOVE_ERROR_AND_RESET(_error) \
495 bt_current_thread_move_error(_error); \
620extern __BT_ATTR_FORMAT_PRINTF(4, 5)
624 uint64_t line_number,
625 const
char *message_format, ...) __BT_NOEXCEPT;
637#define BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_FROM_COMPONENT(_self_component, _message_format, ...) \
638 bt_current_thread_error_append_cause_from_component( \
639 (_self_component), __FILE__, __LINE__, (_message_format), ##__VA_ARGS__)
720extern __BT_ATTR_FORMAT_PRINTF(4, 5)
724 const
char *file_name, uint64_t line_number,
725 const
char *message_format, ...) __BT_NOEXCEPT;
738#define BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_FROM_MESSAGE_ITERATOR(_self_message_iterator, _message_format, ...) \
739 bt_current_thread_error_append_cause_from_message_iterator( \
740 (_self_message_iterator), __FILE__, __LINE__, (_message_format), ##__VA_ARGS__)
812extern __BT_ATTR_FORMAT_PRINTF(4, 5)
816 const
char *file_name, uint64_t line_number,
817 const
char *message_format, ...) __BT_NOEXCEPT;
830#define BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_FROM_COMPONENT_CLASS(_self_component_class, _message_format, ...) \
831 bt_current_thread_error_append_cause_from_component_class( \
832 (_self_component_class), __FILE__, __LINE__, (_message_format), ##__VA_ARGS__)
876extern __BT_ATTR_FORMAT_PRINTF(4, 5)
879 const
char *module_name, const
char *file_name,
880 uint64_t line_number,
881 const
char *message_format, ...) __BT_NOEXCEPT;
898#define BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_FROM_UNKNOWN(_module_name, _message_format, ...) \
899 bt_current_thread_error_append_cause_from_unknown( \
900 (_module_name), __FILE__, __LINE__, (_message_format), ##__VA_ARGS__)
950 const bt_error *error, uint64_t index) __BT_NOEXCEPT;
bt_component_class_type
Component class type enumerators.
Definition component-class.h:202
struct bt_error bt_error
Error.
Definition types.h:34
const char * bt_error_cause_message_iterator_actor_get_component_output_port_name(const bt_error_cause *error_cause)
Returns the name of the output port from which was created the message iterator of which the method a...
const bt_error * bt_current_thread_take_error(void)
Takes the error of the current thread, that is, moves its ownership from the library to the caller.
const char * bt_error_cause_get_message(const bt_error_cause *error_cause)
Returns the message of the error cause error_cause.
bt_current_thread_error_append_cause_status
Status codes for the bt_current_thread_error_append_cause_from_*() functions.
Definition error-reporting.h:534
const char * bt_error_cause_get_file_name(const bt_error_cause *error_cause)
Returns the name of the source file which contains the function which appended the error cause error_...
void bt_error_release(const bt_error *error)
Releases (frees) the error error.
const char * bt_error_cause_get_module_name(const bt_error_cause *error_cause)
Returns the module name of the error cause error_cause.
bt_current_thread_error_append_cause_status bt_current_thread_error_append_cause_from_component_class(bt_self_component_class *self_component_class, const char *file_name, uint64_t line_number, const char *message_format,...)
Appends an error cause to the error of the current thread from a component class method.
const char * bt_error_cause_component_class_actor_get_component_class_name(const bt_error_cause *error_cause)
Returns the name of the component class of which a method appended the error cause error_cause to the...
uint64_t bt_error_get_cause_count(const bt_error *error)
Returns the number of error causes contained in the error error.
const char * bt_error_cause_component_actor_get_component_class_name(const bt_error_cause *error_cause)
Returns the class name of the component of which a method appended the error cause error_cause to the...
bt_current_thread_error_append_cause_status bt_current_thread_error_append_cause_from_component(bt_self_component *self_component, const char *file_name, uint64_t line_number, const char *message_format,...)
Appends an error cause to the error of the current thread from a component method.
void bt_current_thread_clear_error(void)
Releases the error of the current thread, if any.
const char * bt_error_cause_message_iterator_actor_get_plugin_name(const bt_error_cause *error_cause)
Returns the name of the plugin which provides the class of the component of which a message iterator ...
bt_component_class_type bt_error_cause_component_actor_get_component_class_type(const bt_error_cause *error_cause)
Returns the class type of the component of which a method appended the error cause error_cause to the...
bt_component_class_type bt_error_cause_message_iterator_actor_get_component_class_type(const bt_error_cause *error_cause)
Returns the class type of the component of which a message iterator method appended the error cause e...
const char * bt_error_cause_component_actor_get_plugin_name(const bt_error_cause *error_cause)
Returns the name of the plugin which provides the class of the component of which a method appended t...
const char * bt_error_cause_message_iterator_actor_get_component_name(const bt_error_cause *error_cause)
Returns the name of the component of which a message iterator method appended the error cause error_c...
void bt_current_thread_move_error(const bt_error *error)
Moves the ownership of the error error from the caller to the library.
const bt_error_cause * bt_error_borrow_cause_by_index(const bt_error *error, uint64_t index)
Borrows the error cause at index index from the error error.
struct bt_error_cause bt_error_cause
Error cause.
Definition types.h:35
const char * bt_error_cause_component_class_actor_get_plugin_name(const bt_error_cause *error_cause)
Returns the name of the plugin which provides the component class of which a method appended the erro...
bt_current_thread_error_append_cause_status bt_current_thread_error_append_cause_from_unknown(const char *module_name, const char *file_name, uint64_t line_number, const char *message_format,...)
Appends an error cause to the error of the current thread from any function.
bt_error_cause_actor_type bt_error_cause_get_actor_type(const bt_error_cause *error_cause)
Returns the actor type enumerator of the error cause error_cause.
bt_current_thread_error_append_cause_status bt_current_thread_error_append_cause_from_message_iterator(bt_self_message_iterator *self_message_iterator, const char *file_name, uint64_t line_number, const char *message_format,...)
Appends an error cause to the error of the current thread from a message iterator method.
const char * bt_error_cause_message_iterator_actor_get_component_class_name(const bt_error_cause *error_cause)
Returns the class name of the component of which a message iterator method appended the error cause e...
uint64_t bt_error_cause_get_line_number(const bt_error_cause *error_cause)
Returns the line number of the statement which appended the error cause error_cause to the error of t...
bt_error_cause_actor_type
Error cause actor type enumerators.
Definition error-reporting.h:994
const char * bt_error_cause_component_actor_get_component_name(const bt_error_cause *error_cause)
Returns the name of the component of which a method appended the error cause error_cause to the error...
bt_component_class_type bt_error_cause_component_class_actor_get_component_class_type(const bt_error_cause *error_cause)
Returns the name of the component class of which a method appended the error cause error_cause to the...
@ BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_STATUS_MEMORY_ERROR
Out of memory.
Definition error-reporting.h:545
@ BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_STATUS_OK
Success.
Definition error-reporting.h:539
@ BT_ERROR_CAUSE_ACTOR_TYPE_COMPONENT
Component method.
Definition error-reporting.h:1005
@ BT_ERROR_CAUSE_ACTOR_TYPE_MESSAGE_ITERATOR
Message iterator method.
Definition error-reporting.h:1017
@ BT_ERROR_CAUSE_ACTOR_TYPE_UNKNOWN
Any function.
Definition error-reporting.h:999
@ BT_ERROR_CAUSE_ACTOR_TYPE_COMPONENT_CLASS
Component class method.
Definition error-reporting.h:1011
struct bt_self_component_class bt_self_component_class
Self component class.
Definition types.h:72
struct bt_self_component bt_self_component
Self component.
Definition types.h:71
struct bt_self_message_iterator bt_self_message_iterator
Self message iterator.
Definition types.h:86