X-Git-Url: https://git.kernel.dk/?p=fio.git;a=blobdiff_plain;f=log.h;h=f1cf0039a3eb76fa5c2cbfda883e79f97d306d20;hp=ad9d08bbe6730fcf3750ec30e54d5d2b6265f330;hb=8a68c41c2e7e0a1d5128e7e30ab673a6699c2f45;hpb=b0df7176176935b4d39fd196ad35f046bbe10333 diff --git a/log.h b/log.h index ad9d08bb..f1cf0039 100644 --- a/log.h +++ b/log.h @@ -4,14 +4,26 @@ #include #include +#include "lib/output_buffer.h" + extern FILE *f_out; extern FILE *f_err; -extern int log_err(const char *format, ...); -extern int log_info(const char *format, ...); -extern int log_local(const char *format, ...); -extern int log_valist(const char *str, va_list); -extern int log_local_buf(const char *buf, size_t); +extern size_t log_err(const char *format, ...) __attribute__ ((__format__ (__printf__, 1, 2))); +extern size_t log_info(const char *format, ...) __attribute__ ((__format__ (__printf__, 1, 2))); +extern size_t __log_buf(struct buf_output *, const char *format, ...) __attribute__ ((__format__ (__printf__, 2, 3))); +extern size_t log_valist(const char *str, va_list); +extern size_t log_local_buf(const char *buf, size_t); +extern size_t log_info_buf(const char *buf, size_t len); +extern int log_info_flush(void); + +#define log_buf(buf, format, args...) \ +do { \ + if ((buf) != NULL) \ + __log_buf(buf, format, ##args); \ + else \ + log_info(format, ##args); \ +} while (0) enum { FIO_LOG_DEBUG = 1,