|
3 | 3 |
|
4 | 4 | #include "log.h" |
5 | 5 |
|
6 | | -#define log_interface_full_errno(ifname, level, error, ...) \ |
| 6 | +#define log_interface_full_errno_zerook(ifname, level, error, ...) \ |
7 | 7 | ({ \ |
8 | 8 | const char *_ifname = (ifname); \ |
9 | 9 | _ifname ? log_object_internal(level, error, PROJECT_FILE, __LINE__, __func__, "INTERFACE=", _ifname, NULL, NULL, ##__VA_ARGS__) : \ |
10 | 10 | log_internal(level, error, PROJECT_FILE, __LINE__, __func__, ##__VA_ARGS__); \ |
11 | 11 | }) |
12 | 12 |
|
| 13 | +#define log_interface_full_errno(ifname, level, error, ...) \ |
| 14 | + ({ \ |
| 15 | + int _error = (error); \ |
| 16 | + ASSERT_NON_ZERO(_error); \ |
| 17 | + log_interface_full_errno_zerook(ifname, level, _error, __VA_ARGS__); \ |
| 18 | + }) |
| 19 | + |
13 | 20 | /* |
14 | 21 | * The following macros append INTERFACE= to the message. |
15 | 22 | * The macros require a struct named 'Link' which contains 'char *ifname': |
|
21 | 28 | * See, network/networkd-link.h for example. |
22 | 29 | */ |
23 | 30 |
|
24 | | -#define log_link_full_errno(link, level, error, ...) \ |
| 31 | +#define log_link_full_errno_zerook(link, level, error, ...) \ |
25 | 32 | ({ \ |
26 | 33 | const Link *_l = (link); \ |
27 | | - log_interface_full_errno(_l ? _l->ifname : NULL, level, error, ##__VA_ARGS__); \ |
| 34 | + log_interface_full_errno_zerook(_l ? _l->ifname : NULL, level, error, __VA_ARGS__); \ |
| 35 | + }) |
| 36 | + |
| 37 | +#define log_link_full_errno(link, level, error, ...) \ |
| 38 | + ({ \ |
| 39 | + int _error = (error); \ |
| 40 | + ASSERT_NON_ZERO(_error); \ |
| 41 | + log_link_full_errno_zerook(link, level, _error, __VA_ARGS__); \ |
28 | 42 | }) |
29 | 43 |
|
30 | | -#define log_link_full(link, level, ...) (void) log_link_full_errno(link, level, 0, __VA_ARGS__) |
| 44 | +#define log_link_full(link, level, ...) (void) log_link_full_errno_zerook(link, level, 0, __VA_ARGS__) |
31 | 45 |
|
32 | 46 | #define log_link_debug(link, ...) log_link_full(link, LOG_DEBUG, __VA_ARGS__) |
33 | 47 | #define log_link_info(link, ...) log_link_full(link, LOG_INFO, __VA_ARGS__) |
|
0 commit comments