free(out->buf);
}
-void buf_output_add(struct buf_output *out, const char *buf, size_t len)
+size_t buf_output_add(struct buf_output *out, const char *buf, size_t len)
{
while (out->max_buflen - out->buflen < len) {
size_t newlen = out->max_buflen + BUF_INC - out->buflen;
- out->buf = realloc(out->buf, out->max_buflen + BUF_INC);
out->max_buflen += BUF_INC;
+ out->buf = realloc(out->buf, out->max_buflen);
memset(&out->buf[out->buflen], 0, newlen);
}
memcpy(&out->buf[out->buflen], buf, len);
out->buflen += len;
+ return len;
}
-void buf_output_flush(struct buf_output *out)
+size_t buf_output_flush(struct buf_output *out)
{
+ size_t ret = 0;
+
if (out->buflen) {
- log_local_buf(out->buf, out->buflen);
+ ret = log_local_buf(out->buf, out->buflen);
memset(out->buf, 0, out->max_buflen);
out->buflen = 0;
}
+
+ return ret;
}
void buf_output_init(struct buf_output *out, int index);
void buf_output_free(struct buf_output *out);
-void buf_output_add(struct buf_output *out, const char *buf, size_t len);
-void buf_output_flush(struct buf_output *out);
+size_t buf_output_add(struct buf_output *out, const char *buf, size_t len);
+size_t buf_output_flush(struct buf_output *out);
#endif
#include "fio.h"
-int log_valist(const char *str, va_list args)
+size_t log_valist(const char *str, va_list args)
{
char buffer[1024];
size_t len;
return len;
}
-int log_local_buf(const char *buf, size_t len)
+size_t log_local_buf(const char *buf, size_t len)
{
if (log_syslog)
syslog(LOG_INFO, "%s", buf);
return len;
}
-int log_info(const char *format, ...)
+size_t log_info(const char *format, ...)
{
char buffer[1024];
va_list args;
return fwrite(buffer, len, 1, f_out);
}
-int __log_buf(struct buf_output *buf, const char *format, ...)
+size_t __log_buf(struct buf_output *buf, const char *format, ...)
{
char buffer[1024];
va_list args;
va_end(args);
len = min(len, sizeof(buffer) - 1);
- buf_output_add(buf, buffer, len);
- return 0;
+ return buf_output_add(buf, buffer, len);
}
int log_info_flush(void)
return fflush(f_out);
}
-int log_err(const char *format, ...)
+size_t log_err(const char *format, ...)
{
char buffer[1024];
va_list args;
extern FILE *f_out;
extern FILE *f_err;
-extern int log_err(const char *format, ...) __attribute__ ((__format__ (__printf__, 1, 2)));
-extern int log_info(const char *format, ...) __attribute__ ((__format__ (__printf__, 1, 2)));
-extern int __log_buf(struct buf_output *, const char *format, ...) __attribute__ ((__format__ (__printf__, 2, 3)));
-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 int log_info_flush(void);
#define log_buf(buf, format, args...) \
}
static void show_option_range(struct fio_option *o,
- int (*logger)(const char *format, ...))
+ size_t (*logger)(const char *format, ...))
{
if (o->type == FIO_OPT_FLOAT_LIST) {
if (o->minfp == DBL_MIN && o->maxfp == DBL_MAX)
"no argument (opt)",
"deprecated",
};
- int (*logger)(const char *format, ...);
+ size_t (*logger)(const char *format, ...);
if (is_err)
logger = log_err;