X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=libtest%2Fresult.cc;h=9a1c8fba4eae58f09b613faf0dcd01beaec187d1;hb=cb3ca2b63f9ddb2e070814623a3965c88a84eea7;hp=65038f91e19af2f4d7e330c87ac8e6ecf75d5d44;hpb=97b73d47e6a3d5729ba13304ff355a737a34f1b4;p=awesomized%2Flibmemcached diff --git a/libtest/result.cc b/libtest/result.cc index 65038f91..9a1c8fba 100644 --- a/libtest/result.cc +++ b/libtest/result.cc @@ -2,7 +2,7 @@ * * Data Differential YATL (i.e. libtest) library * - * Copyright (C) 2012 Data Differential, http://datadifferential.com/ + * Copyright (C) 2012-2013 Data Differential, http://datadifferential.com/ * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are @@ -43,24 +43,83 @@ namespace libtest { __test_result::__test_result(const char *file_arg, int line_arg, const char *func_arg): _line(line_arg), _file(file_arg), - _func(func_arg) + _func(func_arg), + _error_message(NULL), + _error_message_size(0) { } +#ifndef __INTEL_COMPILER +# pragma GCC diagnostic ignored "-Wformat-nonliteral" +#endif +void __test_result::init(va_list args_) +{ + const char *format= va_arg(args_, const char *); + _error_message_size= vasprintf(&_error_message, format, args_); + assert(_error_message_size != -1); + if (_error_message_size > 0) + { + _error_message_size++; + } +} + +__test_result::~__test_result() throw() +{ + free(_error_message); +} + +__test_result::__test_result(const __test_result& other) : + _line(other._line), + _file(other._file), + _func(other._func), + _error_message_size(other._error_message_size) +{ + if (_error_message_size > 0) + { + _error_message= (char*) malloc(_error_message_size); + if (_error_message) + { + memcpy(_error_message, other._error_message, _error_message_size); + } + else + { + _error_message_size= -1; + } + } +} + __success::__success(const char *file_arg, int line_arg, const char *func_arg): __test_result(file_arg, line_arg, func_arg) { } -__skipped::__skipped(const char *file_arg, int line_arg, const char *func_arg): +__skipped::__skipped(const char *file_arg, int line_arg, const char *func_arg, ...): __test_result(file_arg, line_arg, func_arg) +{ + va_list args; + va_start(args, func_arg); + init(args); + va_end(args); +} + +__skipped::__skipped(const __skipped& other) : + __test_result(other) { } -__failure::__failure(const char *file_arg, int line_arg, const char *func_arg, const std::string& mesg): +__failure::__failure(const char *file_arg, int line_arg, const char *func_arg, ...) : __test_result(file_arg, line_arg, func_arg) { - snprintf(_error_message, sizeof(_error_message), "%.*s", int(mesg.size()), mesg.c_str()); + va_list args; + va_start(args, func_arg); + init(args); + va_end(args); } +__failure::__failure(const __failure& other) : + __test_result(other) +{ +} + + } // namespace libtest