Babeltrace 2 C API 2.1.0
Open-source trace manipulation framework
|
Error reporting functions and macros.
This API offers functions and macros to report rich errors from a user function (a component class method, a query operation, or a trace processing graph listener, for example) to any function caller.
Because Babeltrace 2 orchestrates pieces written by different authors, it's important that an error which occurs deep into the function call stack can percolate up to its callers.
The very basic mechanism to report an error from a function is to return an error status (a status code enumerator which contains the word ERROR
): each function caller can clean its own context and return an error status code itself until one caller "catches" the status code and reacts to it. For example, the reaction can be to show an error message to the end user.
This error reporting API adds a layer so that each function which returns an error status code can append a message which describes the cause of the error within the context of the function.
Functions append error causes to the error of the current thread. Having one error object per thread makes this API thread-safe.
Here's a visual, step-by-step example:
The "consume" method of the sink component appends the error cause "Cannot consume upstream message iterator's messages" and returns BT_COMPONENT_CLASS_SINK_CONSUME_METHOD_STATUS_ERROR.
At this point, the error of the current thread contains four causes:
This list of error causes is much richer for the end user than dealing only with BT_GRAPH_RUN_STATUS_ERROR (the last error status code).
Both error (bt_error) and error cause (bt_error_cause) objects are unique objects:
When your function returns an error status code, use one of the bt_current_thread_error_append_cause_from_*()
functions or BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_FROM_*()
macros to append an error cause to the error of the current thread. Use the appropriate function or macro depending on the actor of your function amongst:
Append an error cause from a component method.
Use bt_current_thread_error_append_cause_from_component() or BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_FROM_COMPONENT().
Append an error cause from a message iterator method.
Use bt_current_thread_error_append_cause_from_message_iterator() or BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_FROM_MESSAGE_ITERATOR().
Append an error cause from a component class method ("query" method).
Use bt_current_thread_error_append_cause_from_component_class() or BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_FROM_COMPONENT_CLASS().
Append an error cause from any other function, for example a graph listener or a function of your user application).
Use bt_current_thread_error_append_cause_from_unknown() or BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_FROM_UNKNOWN().
The BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_FROM_*()
macros uses __FILE__
and __LINE__
as the file name and line number parameters of their corresponding bt_current_thread_error_append_cause_from_*()
function.
If any libbabeltrace2 function you call returns an error status code, then do one of:
Return an error status code too.
In that case, you can append an error cause to the error of the current thread.
Take the error of the current thread with bt_current_thread_take_error().
This function moves the ownership of the error object from the library to you.
At this point, you can inspect its causes with bt_error_get_cause_count() and bt_error_borrow_cause_by_index(), and then do one of:
Call bt_error_release() to free the error object.
In object-oriented programming terms, this corresponds to catching an exception and discarding it.
Call bt_current_thread_move_error() to move the ownership of the error object back to the library.
In object-oriented programming terms, this corresponds to catching an exception and rethrowing it.
bt_current_thread_clear_error() is a helper which is the equivalent of:
All error causes have the type bt_error_cause.
There are four types of error cause actors:
Get the type enumerator of the actor of an error cause with bt_error_cause_get_actor_type().
An error cause has the following common properties:
Description of the error cause.
Name of the module causing the error.
For example, libbabeltrace2 uses "libbabeltrace2" and the babeltrace2
CLI tool uses "Babeltrace CLI".
Name of the source file causing the error.
Line number of the statement causing the error.
An error cause with a component actor has the following specific properties:
Name of the component.
Name of the class of the component.
Use bt_error_cause_component_actor_get_component_class_type().
Type of the class of the component.
Use bt_error_cause_component_actor_get_component_class_name().
Name of the plugin which provides the class of the component, if any.
An error cause with a message iterator actor has the following specific properties:
Name of the component output port from which the message iterator was created.
Use bt_error_cause_message_iterator_actor_get_component_output_port_name().
Name of the component.
Use bt_error_cause_message_iterator_actor_get_component_name().
Name of the class of the component.
Use bt_error_cause_message_iterator_actor_get_component_class_name().
Type of the class of the component.
Use bt_error_cause_message_iterator_actor_get_component_class_type().
Name of the plugin which provides the class of the component, if any.
Use bt_error_cause_message_iterator_actor_get_plugin_name().
An error cause with a component class actor has the following specific properties:
Name of the component class.
Use bt_error_cause_component_class_actor_get_component_class_type().
Type of the component class.
Use bt_error_cause_component_class_actor_get_component_class_name().
Name of the plugin which provides the component class, if any.
Error cause appending | |
enum | bt_current_thread_error_append_cause_status { BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_STATUS_OK , BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_STATUS_MEMORY_ERROR } |
Status codes for the bt_current_thread_error_append_cause_from_*() functions. More... | |
typedef enum bt_current_thread_error_append_cause_status | bt_current_thread_error_append_cause_status |
Status codes for the bt_current_thread_error_append_cause_from_*() functions. | |
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. | |
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. | |
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. | |
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. | |
#define | BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_FROM_COMPONENT(_self_component, _message_format, ...) |
Appends an error cause to the error of the current thread from a component method using __FILE__ and __LINE__ as the source file name and line number. | |
#define | BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_FROM_MESSAGE_ITERATOR(_self_message_iterator, _message_format, ...) |
Appends an error cause to the error of the current thread from a message iterator method using __FILE__ and __LINE__ as the source file name and line number. | |
#define | BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_FROM_COMPONENT_CLASS(_self_component_class, _message_format, ...) |
Appends an error cause to the error of the current thread from a component class method using __FILE__ and __LINE__ as the source file name and line number. | |
#define | BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_FROM_UNKNOWN(_module_name, _message_format, ...) |
Appends an error cause to the error of the current thread from any function using __FILE__ and __LINE__ as the source file name and line number. | |
Error cause: common | |
enum | bt_error_cause_actor_type { BT_ERROR_CAUSE_ACTOR_TYPE_UNKNOWN , BT_ERROR_CAUSE_ACTOR_TYPE_COMPONENT , BT_ERROR_CAUSE_ACTOR_TYPE_COMPONENT_CLASS , BT_ERROR_CAUSE_ACTOR_TYPE_MESSAGE_ITERATOR } |
Error cause actor type enumerators. More... | |
typedef enum bt_error_cause_actor_type | bt_error_cause_actor_type |
Error cause actor type enumerators. | |
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. | |
const char * | bt_error_cause_get_message (const bt_error_cause *error_cause) |
Returns the message of the error cause error_cause. | |
const char * | bt_error_cause_get_module_name (const bt_error_cause *error_cause) |
Returns the module name of the error cause error_cause. | |
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_cause to the error of the current thread. | |
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 the current thread. | |
Types | |
typedef struct bt_error | bt_error |
Error. | |
typedef struct bt_error_cause | bt_error_cause |
Error cause. | |
Error of the current thread | |
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. | |
void | bt_current_thread_move_error (const bt_error *error) |
Moves the ownership of the error error from the caller to the library. | |
void | bt_current_thread_clear_error (void) |
Releases the error of the current thread, if any. | |
#define | BT_CURRENT_THREAD_MOVE_ERROR_AND_RESET(_error) |
Moves the ownership of the error _error from the caller to the library, and then sets _error to NULL . | |
Error | |
uint64_t | bt_error_get_cause_count (const bt_error *error) |
Returns the number of error causes contained in the error error. | |
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. | |
void | bt_error_release (const bt_error *error) |
Releases (frees) the error error. | |
Error cause with a component actor | |
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 of the current thread. | |
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 error of the current thread. | |
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 error of the current thread. | |
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 the error cause error_cause to the error of the current thread. | |
Error cause with a message iterator actor | |
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 appended the error cause error_cause to the error of the current thread. | |
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_cause to the error of the current thread. | |
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 error_cause to the error of the current thread. | |
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 error_cause to the error of the current thread. | |
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 method appended the error cause error_cause to the error of the current thread. | |
Error cause with a component class actor | |
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 error of the current thread. | |
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 error of the current thread. | |
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 error cause error_cause to the error of the current thread. | |
#define BT_CURRENT_THREAD_MOVE_ERROR_AND_RESET | ( | _error | ) |
Moves the ownership of the error _error from the caller to the library, and then sets _error to NULL
.
[in] | _error | Error of which to move the ownership from you to the library. |
NULL
. #define BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_FROM_COMPONENT | ( | _self_component, | |
_message_format, | |||
... ) |
Appends an error cause to the error of the current thread from a component method using __FILE__
and __LINE__
as the source file name and line number.
This macro calls bt_current_thread_error_append_cause_from_component() with __FILE__
and __LINE__
as its file_name and line_number parameters.
#define BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_FROM_MESSAGE_ITERATOR | ( | _self_message_iterator, | |
_message_format, | |||
... ) |
Appends an error cause to the error of the current thread from a message iterator method using __FILE__
and __LINE__
as the source file name and line number.
This macro calls bt_current_thread_error_append_cause_from_message_iterator() with __FILE__
and __LINE__
as its file_name and line_number parameters.
#define BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_FROM_COMPONENT_CLASS | ( | _self_component_class, | |
_message_format, | |||
... ) |
Appends an error cause to the error of the current thread from a component class method using __FILE__
and __LINE__
as the source file name and line number.
This macro calls bt_current_thread_error_append_cause_from_component_class() with __FILE__
and __LINE__
as its file_name and line_number parameters.
#define BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_FROM_UNKNOWN | ( | _module_name, | |
_message_format, | |||
... ) |
Appends an error cause to the error of the current thread from any function using __FILE__
and __LINE__
as the source file name and line number.
Use this function when you cannot use BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_FROM_COMPONENT(), BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_FROM_MESSAGE_ITERATOR(), or BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_FROM_COMPONENT_CLASS().
This macro calls bt_current_thread_error_append_cause_from_unknown() with __FILE__
and __LINE__
as its file_name and line_number parameters.
|
extern |
Takes the error of the current thread, that is, moves its ownership from the library to the caller.
This function can return NULL
if the current thread has no error.
Once you're done with the returned error, do one of:
Call bt_error_release() to free the error object.
In object-oriented programming terms, this corresponds to catching an exception and discarding it.
Call bt_current_thread_move_error() to move the ownership of the error object back to the library.
In object-oriented programming terms, this corresponds to catching an exception and rethrowing it.
NULL
if the current thread has no error.NULL
, then the caller owns the returned error.
|
extern |
Moves the ownership of the error error from the caller to the library.
After you call this function, you don't own error anymore.
In object-oriented programming terms, calling this function corresponds to catching an exception and rethrowing it.
You can instead release (free) the error with bt_error_release(), which, in object-oriented programming terms, corresponds to catching an exception and discarding it.
[in] | error | Error of which to move the ownership from you to the library. |
NULL
. NULL
to the expression.
|
extern |
Releases the error of the current thread, if any.
This function is equivalent to:
|
extern |
Appends an error cause to the error of the current thread from a component method.
This this a printf()
-like function starting from the format string parameter message_format.
On success, the appended module name of the error cause (see bt_error_cause_get_module_name()) is:
or
if no plugin provides the class of self_component, with:
NAME
Name of self_component.
CC-TYPE
Type of the class of self_component (src
, flt
, or sink
).
PLUGIN-NAME
Name of the plugin which provides the class of self_component.
CC-NAME
[in] | self_component | Self component of the appending method. |
[in] | file_name | Name of the source file containing the method which appends the error cause. |
[in] | line_number | Line number of the statement which appends the error cause. |
[in] | message_format | Format string which specifies how the function converts the subsequent arguments (like printf() ). |
BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_STATUS_OK | Success. |
BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_STATUS_MEMORY_ERROR | Out of memory. |
NULL
. NULL
. NULL
. printf()
-like format string.__FILE__
and __LINE__
as the file_name and line_number parameters.
|
extern |
Appends an error cause to the error of the current thread from a message iterator method.
This this a printf()
-like function starting from the format string parameter message_format.
On success, the appended module name of the error cause (see bt_error_cause_get_module_name()) is:
or
if no plugin provides the component class of self_message_iterator, with:
COMP-NAME
Name of the component of self_message_iterator.
OUT-PORT-NAME
Name of the output port from which self_message_iterator. was created.
CC-TYPE
Type of the component class of self_message_iterator (src
, flt
, or sink
).
PLUGIN-NAME
Name of the plugin which provides the component class of self_message_iterator.
CC-NAME
[in] | self_message_iterator | Self message iterator of the appending method. |
[in] | file_name | Name of the source file containing the method which appends the error cause. |
[in] | line_number | Line number of the statement which appends the error cause. |
[in] | message_format | Format string which specifies how the function converts the subsequent arguments (like printf() ). |
BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_STATUS_OK | Success. |
BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_STATUS_MEMORY_ERROR | Out of memory. |
NULL
. NULL
. NULL
. printf()
-like format string.__FILE__
and __LINE__
as the file_name and line_number parameters.
|
extern |
Appends an error cause to the error of the current thread from a component class method.
This this a printf()
-like function starting from the format string parameter message_format.
As of Babeltrace 2.0, the only component class method is the query method.
On success, the appended module name of the error cause (see bt_error_cause_get_module_name()) is:
or
if no plugin provides self_component_class, with:
CC-TYPE
Type of self_component_class (src
, flt
, or sink
).
PLUGIN-NAME
Name of the plugin which provides self_component_class.
CC-NAME
[in] | self_component_class | Self component class of the appending method. |
[in] | file_name | Name of the source file containing the method which appends the error cause. |
[in] | line_number | Line number of the statement which appends the error cause. |
[in] | message_format | Format string which specifies how the function converts the subsequent arguments (like printf() ). |
BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_STATUS_OK | Success. |
BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_STATUS_MEMORY_ERROR | Out of memory. |
NULL
. NULL
. NULL
. printf()
-like format string.__FILE__
and __LINE__
as the file_name and line_number parameters.
|
extern |
Appends an error cause to the error of the current thread from any function.
Use this function when you cannot use bt_current_thread_error_append_cause_from_component(), bt_current_thread_error_append_cause_from_message_iterator(), or bt_current_thread_error_append_cause_from_component_class().
This this a printf()
-like function starting from the format string parameter message_format.
[in] | module_name | Module name of the error cause to append. |
[in] | file_name | Name of the source file containing the method which appends the error cause. |
[in] | line_number | Line number of the statement which appends the error cause. |
[in] | message_format | Format string which specifies how the function converts the subsequent arguments (like printf() ). |
BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_STATUS_OK | Success. |
BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_STATUS_MEMORY_ERROR | Out of memory. |
NULL
. NULL
. NULL
. printf()
-like format string.__FILE__
and __LINE__
as the file_name and line_number parameters.
|
extern |
Returns the number of error causes contained in the error error.
[in] | error | Error of which to get the number of contained error causes. |
NULL
.
|
extern |
Borrows the error cause at index index from the error error.
[in] | error | Error from which to borrow the error cause at index index. |
[in] | index | Index of the error cause to borrow from error. |
Borrowed reference of the error cause of error at index index.
The returned pointer remains valid until error is modified.
NULL
.
|
extern |
Releases (frees) the error error.
After you call this function, error doesn't exist.
Take the error of the current thread with bt_current_thread_take_error().
In object-oriented programming terms, calling this function corresponds to catching an exception and discarding it.
You can instead move the ownership of error to the library with bt_current_thread_move_error(), which, in object-oriented programming terms, corresponds to catching an exception and rethrowing it.
[in] | error | Error to release (free). |
NULL
.
|
extern |
Returns the actor type enumerator of the error cause error_cause.
[in] | error_cause | Error cause of which to get the actor type enumerator. |
NULL
.
|
extern |
Returns the message of the error cause error_cause.
[in] | error_cause | Error cause of which to get the message. |
Message of error_cause.
The returned pointer remains valid as long as the error which contains error_cause exists.
NULL
.
|
extern |
Returns the module name of the error cause error_cause.
[in] | error_cause | Error cause of which to get the module name. |
Module name of error_cause.
The returned pointer remains valid as long as the error which contains error_cause exists.
NULL
.
|
extern |
Returns the name of the source file which contains the function which appended the error cause error_cause to the error of the current thread.
[in] | error_cause | Error cause of which to get the source file name. |
Source file name of error_cause.
The returned pointer remains valid as long as the error which contains error_cause exists.
NULL
.
|
extern |
Returns the line number of the statement which appended the error cause error_cause to the error of the current thread.
[in] | error_cause | Error cause of which to get the line number of the source statement. |
NULL
.
|
extern |
Returns the name of the component of which a method appended the error cause error_cause to the error of the current thread.
[in] | error_cause | Error cause of which to get the component name. |
Component name of error_cause.
The returned pointer remains valid as long as the error which contains error_cause exists.
NULL
.
|
extern |
Returns the class type of the component of which a method appended the error cause error_cause to the error of the current thread.
[in] | error_cause | Error cause of which to get the component class type. |
NULL
.
|
extern |
Returns the class name of the component of which a method appended the error cause error_cause to the error of the current thread.
[in] | error_cause | Error cause of which to get the component class name. |
Component class name of error_cause.
The returned pointer remains valid as long as the error which contains error_cause exists.
NULL
.
|
extern |
Returns the name of the plugin which provides the class of the component of which a method appended the error cause error_cause to the error of the current thread.
This function returns NULL
if no plugin provides the component class of the error cause.
[in] | error_cause | Error cause of which to get the plugin name. |
Plugin name of error_cause, or NULL
if no plugin provides the component class of error_cause.
The returned pointer remains valid as long as the error which contains error_cause exists.
NULL
.
|
extern |
Returns the name of the output port from which was created the message iterator of which the method appended the error cause error_cause to the error of the current thread.
[in] | error_cause | Error cause of which to get the output port name. |
Output port name of error_cause.
The returned pointer remains valid as long as the error which contains error_cause exists.
NULL
.
|
extern |
Returns the name of the component of which a message iterator method appended the error cause error_cause to the error of the current thread.
[in] | error_cause | Error cause of which to get the component name. |
Component name of error_cause.
The returned pointer remains valid as long as the error which contains error_cause exists.
NULL
.
|
extern |
Returns the class type of the component of which a message iterator method appended the error cause error_cause to the error of the current thread.
[in] | error_cause | Error cause of which to get the component class type. |
NULL
.
|
extern |
Returns the class name of the component of which a message iterator method appended the error cause error_cause to the error of the current thread.
[in] | error_cause | Error cause of which to get the component class name. |
Component class name of error_cause.
The returned pointer remains valid as long as the error which contains error_cause exists.
NULL
.
|
extern |
Returns the name of the plugin which provides the class of the component of which a message iterator method appended the error cause error_cause to the error of the current thread.
This function returns NULL
if no plugin provides the component class of the error cause.
[in] | error_cause | Error cause of which to get the plugin name. |
Plugin name of error_cause, or NULL
if no plugin provides the component class of error_cause.
The returned pointer remains valid as long as the error which contains error_cause exists.
NULL
.
|
extern |
Returns the name of the component class of which a method appended the error cause error_cause to the error of the current thread.
[in] | error_cause | Error cause of which to get the component class name. |
NULL
.
|
extern |
Returns the name of the component class of which a method appended the error cause error_cause to the error of the current thread.
[in] | error_cause | Error cause of which to get the component class name. |
Component class name of error_cause.
The returned pointer remains valid as long as the error which contains error_cause exists.
NULL
.
|
extern |
Returns the name of the plugin which provides the component class of which a method appended the error cause error_cause to the error of the current thread.
This function returns NULL
if no plugin provides the component class of the error cause.
[in] | error_cause | Error cause of which to get the plugin name. |
Plugin name of error_cause, or NULL
if no plugin provides the component class of error_cause.
The returned pointer remains valid as long as the error which contains error_cause exists.
NULL
.