X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=libtest%2Ffatal.cc;h=cdccff82aec67818d1c51e0389c751abc1cbbf19;hb=21f850c451cb7db8a0085ddcc892290ecac859eb;hp=c61b5cfb8fe0ea842b5f99e0f7f5781c20dfcc50;hpb=6278f4fcc2b81952d7420c081961dd83935c8c85;p=awesomized%2Flibmemcached diff --git a/libtest/fatal.cc b/libtest/fatal.cc index c61b5cfb..cdccff82 100644 --- a/libtest/fatal.cc +++ b/libtest/fatal.cc @@ -40,11 +40,20 @@ namespace libtest { -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) +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_) { va_list args; va_start(args, format); @@ -52,8 +61,6 @@ fatal::fatal(const char *file_arg, int line_arg, const char *func_arg, const cha 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); } @@ -85,23 +92,34 @@ void fatal::increment_disabled_counter() _counter++; } -disconnected::disconnected(const char *file_arg, int line_arg, const char *func_arg, - const char *instance, const in_port_t port, +disconnected::disconnected(const char *file_, int line_, const char *func_, + const std::string& instance, const in_port_t port, const char *format, ...) : - std::runtime_error(func_arg), - _port(port), - _line(line_arg), - _file(file_arg), - _func(func_arg) + 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) { - 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", last_error); + snprintf(_error_message, sizeof(_error_message), "%s:%u %s", instance.c_str(), uint32_t(port), last_error); } } // namespace libtest