X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=libtest%2Ffatal.cc;h=3327e3819a1bfda7901e406b16055377c166a9f8;hb=1ed39cb2d0601d753ef54be65f24334097f48805;hp=288d53a4b1ccd6f3f487406d3593c9578c6bfdb6;hpb=e9c7a25491f4cf9265a926b7d9848bd70acaf7aa;p=awesomized%2Flibmemcached diff --git a/libtest/fatal.cc b/libtest/fatal.cc index 288d53a4..3327e381 100644 --- a/libtest/fatal.cc +++ b/libtest/fatal.cc @@ -34,12 +34,13 @@ * */ -#include +#include "libtest/yatlcon.h" #include #include namespace libtest { +#pragma GCC diagnostic ignored "-Wformat-nonliteral" fatal::fatal(const char *file_arg, int line_arg, const char *func_arg, const char *format, ...) : std::runtime_error(func_arg), _line(line_arg), @@ -54,7 +55,7 @@ fatal::fatal(const char *file_arg, int line_arg, const char *func_arg, const cha strncpy(_mesg, last_error, sizeof(_mesg)); - snprintf(_error_message, sizeof(_error_message), "%s:%d FATAL:%s (%s)", _file, _line, last_error, _func); + snprintf(_error_message, sizeof(_error_message), "%.*s", last_error_length, last_error); } static bool _disabled= false; @@ -67,11 +68,13 @@ bool fatal::is_disabled() void fatal::disable() { + _counter= 0; _disabled= true; } void fatal::enable() { + _counter= 0; _disabled= false; } @@ -85,8 +88,9 @@ void fatal::increment_disabled_counter() _counter++; } +#pragma GCC diagnostic ignored "-Wformat-nonliteral" disconnected::disconnected(const char *file_arg, int line_arg, const char *func_arg, - const char *instance, const in_port_t port, + const std::string& instance, const in_port_t port, const char *format, ...) : std::runtime_error(func_arg), _port(port), @@ -94,14 +98,13 @@ disconnected::disconnected(const char *file_arg, int line_arg, const char *func_ _file(file_arg), _func(func_arg) { - strncpy(_instance, instance, sizeof(_instance)); va_list args; va_start(args, format); char last_error[BUFSIZ]; (void)vsnprintf(last_error, sizeof(last_error), format, args); va_end(args); - snprintf(_error_message, sizeof(_error_message), "%s:%d FATAL:%s (%s)", _file, _line, last_error, _func); + snprintf(_error_message, sizeof(_error_message), "%s:%u %s", instance.c_str(), uint32_t(port), last_error); } } // namespace libtest