+#define _bt_printfe(fp, kindstr, perrorstr, fmt, args...) \
+ fprintf(fp, "[%s]%s%s%s: %s: " fmt "\n", \
+ kindstr, \
+ babeltrace_debug ? " \"" : "", \
+ babeltrace_debug ? __func__ : "", \
+ babeltrace_debug ? "\"" : "", \
+ perrorstr, \
+ ## args)
+
+#define _bt_printfle(fp, kindstr, lineno, perrorstr, fmt, args...) \
+ fprintf(fp, "[%s]%s%s%s at line %u: %s: " fmt "\n", \
+ kindstr, \
+ babeltrace_debug ? " \"" : "", \
+ babeltrace_debug ? __func__ : "", \
+ babeltrace_debug ? "\"" : "", \
+ lineno, \
+ perrorstr, \
+ ## args)
+
+#define _bt_printf_perror(fp, fmt, args...) \
+ ({ \
+ char buf[PERROR_BUFLEN] = "Error in strerror_r()"; \
+ compat_strerror_r(errno, buf, sizeof(buf)); \
+ _bt_printfe(fp, "error", buf, fmt, ## args); \
+ })
+
+#define _bt_printfl_perror(fp, lineno, fmt, args...) \
+ ({ \
+ char buf[PERROR_BUFLEN] = "Error in strerror_r()"; \
+ compat_strerror_r(errno, buf, sizeof(buf)); \
+ _bt_printfle(fp, "error", lineno, buf, fmt, ## args); \
+ })
+