X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=libtest%2Ffatal.cc;h=e96d723c8e7350269513c0c881284c1fce4565f0;hb=9065046a3fd404f72fb090cb0da65cfa8443032f;hp=cdccff82aec67818d1c51e0389c751abc1cbbf19;hpb=6cca0302addd6ea9714f2b8deff2c48aab3002ef;p=awesomized%2Flibmemcached diff --git a/libtest/fatal.cc b/libtest/fatal.cc index cdccff82..e96d723c 100644 --- a/libtest/fatal.cc +++ b/libtest/fatal.cc @@ -34,26 +34,18 @@ * */ -#include +#include "libtest/yatlcon.h" #include #include namespace libtest { -exception::exception(const char *file_, int line_, const char *func_) : - std::runtime_error(func_), - _file(file_), - _line(line_), - _func(func_) - { - } - -#ifndef __INTEL_COMPILER #pragma GCC diagnostic ignored "-Wformat-nonliteral" -#endif - -fatal::fatal(const char *file_, int line_, const char *func_, const char *format, ...) : - exception(file_, line_, func_) +fatal::fatal(const char *file_arg, int line_arg, const char *func_arg, const char *format, ...) : + std::runtime_error(func_arg), + _line(line_arg), + _file(file_arg), + _func(func_arg) { va_list args; va_start(args, format); @@ -61,6 +53,8 @@ fatal::fatal(const char *file_, int line_, const char *func_, const char *format int last_error_length= vsnprintf(last_error, sizeof(last_error), format, args); va_end(args); + strncpy(_mesg, last_error, sizeof(_mesg)); + snprintf(_error_message, sizeof(_error_message), "%.*s", last_error_length, last_error); } @@ -74,11 +68,13 @@ bool fatal::is_disabled() void fatal::disable() { + _counter= 0; _disabled= true; } void fatal::enable() { + _counter= 0; _disabled= false; } @@ -92,26 +88,15 @@ void fatal::increment_disabled_counter() _counter++; } -disconnected::disconnected(const char *file_, int line_, const char *func_, +#pragma GCC diagnostic ignored "-Wformat-nonliteral" +disconnected::disconnected(const char *file_arg, int line_arg, const char *func_arg, const std::string& instance, const in_port_t port, const char *format, ...) : - exception(file_, line_, func_), - _port(port) -{ - 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:%u %s", instance.c_str(), uint32_t(port), last_error); -} - -start::start(const char *file_, int line_, const char *func_, - const std::string& instance, const in_port_t port, - const char *format, ...) : - exception(file_, line_, func_), - _port(port) + std::runtime_error(func_arg), + _port(port), + _line(line_arg), + _file(file_arg), + _func(func_arg) { va_list args; va_start(args, format); @@ -123,4 +108,3 @@ start::start(const char *file_, int line_, const char *func_, } } // namespace libtest -