2 * SPDX-License-Identifier: MIT
4 * Copyright (c) 2022 Simon Marchi <simon.marchi@efficios.com>
5 * Copyright (c) 2022 Philippe Proulx <eeppeliteloop@gmail.com>
8 #ifndef BABELTRACE_CPP_COMMON_CFG_ERROR_REPORTING_HPP
9 #define BABELTRACE_CPP_COMMON_CFG_ERROR_REPORTING_HPP
11 #include <babeltrace2/babeltrace.h>
13 #include "cfg-logging.hpp"
16 * Appends a cause to the error of the current thread using the logging
17 * configuration `_log_cfg`.
19 #define BT_APPEND_CAUSE_EX(_log_cfg, _fmt, ...) \
21 if ((_log_cfg).selfMsgIter()) { \
22 BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_FROM_MESSAGE_ITERATOR((_log_cfg).selfMsgIter(), \
23 _fmt, ##__VA_ARGS__); \
24 } else if ((_log_cfg).selfComp()) { \
25 BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_FROM_COMPONENT((_log_cfg).selfComp(), _fmt, \
27 } else if ((_log_cfg).selfCompCls()) { \
28 BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_FROM_COMPONENT_CLASS((_log_cfg).selfCompCls(), \
29 _fmt, ##__VA_ARGS__); \
31 BT_CURRENT_THREAD_ERROR_APPEND_CAUSE_FROM_UNKNOWN((_log_cfg).moduleName(), _fmt, \
36 #define BT_APPEND_CAUSE(_fmt, ...) BT_APPEND_CAUSE_EX((BT_CLOG_CFG), _fmt, ##__VA_ARGS__)
39 * Appends a cause to the error of the current thread using the logging
40 * configuration `_log_cfg`.
42 #define BT_APPEND_CAUSE_STR_EX(_log_cfg, _str) BT_APPEND_CAUSE_EX((_log_cfg), "%s", _str)
44 #define BT_APPEND_CAUSE_STR(_str) BT_APPEND_CAUSE_STR_EX((BT_CLOG_CFG), _str)
47 * Appends a cause with an errno message to the error of the current
48 * thread using the logging configuration `_log_cfg`.
50 #define BT_APPEND_CAUSE_ERRNO_EX(_log_cfg, _init_msg, _fmt, ...) \
52 const auto errStr = g_strerror(errno); \
53 BT_APPEND_CAUSE_EX((_log_cfg), "%s: %s" _fmt, _init_msg, errStr, ##__VA_ARGS__); \
56 #define BT_APPEND_CAUSE_ERRNO(_init_msg, _fmt, ...) \
57 BT_APPEND_CAUSE_EX((BT_CLOG_CFG), _init_msg, _fmt, ##__VA_ARGS__)
59 #endif /* BABELTRACE_CPP_COMMON_CFG_ERROR_REPORTING_HPP */