/* * The ManaPlus Client * Copyright (C) 2012-2016 The ManaPlus Developers * * This file is part of The ManaPlus Client. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #ifdef ENABLE_ASSERTS #include "utils/checkutils.h" #include "logger.h" #if defined __linux__ || defined __linux #include #endif // defined __linux__ || defined __linux #include "debug.h" bool reportFalseReal(const bool val, const char *const text, const char *const file, const unsigned line, const char *const func) { if (!val) reportStack(file, line, func, "Detected false value", text); return val; } bool reportTrueReal(const bool val, const char *const text, const char *const file, const unsigned line, const char *const func) { if (val) reportStack(file, line, func, "Detected true value", text); return val; } bool failFalseReal(const bool val, const char *const text, const char *const file, const unsigned line, const char *const func) { if (!val) { reportStack(file, line, func, "Detected false value", text); throw new std::exception; } return val; } bool failTrueReal(const bool val, const char *const text, const char *const file, const unsigned line, const char *const func) { if (val) { reportStack(file, line, func, "Detected true value", text); throw new std::exception; } return val; } void reportStack(const char *const file, const unsigned int line, const char *const func, const char *const name, const char *const text) { #if defined __linux__ || defined __linux void *array[15]; int size; char **strings; int i; #endif // defined __linux__ || defined __linux logger->log("--- %s --------------------------------------------", name); logger->assertLog("%s:%u: '%s' in function `%s'", file, line, text, func); #if defined __linux__ || defined __linux size = static_cast(backtrace(array, 15)); strings = backtrace_symbols(array, size); for (i = 0; i < size; i++) logger->log1(strings[i]); free(strings); #endif // defined __linux__ || defined __linux } #endif // ENABLE_ASSERTS