/* * The ManaPlus Client * Copyright (C) 2012-2017 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 <http://www.gnu.org/licenses/>. */ #ifdef ENABLE_ASSERTS #include "utils/checkutils.h" #include "logger.h" #ifndef ANDROID #if defined __linux__ || defined __linux #include <execinfo.h> #endif // defined __linux__ || defined __linux #endif // ANDROID #include "debug.h" void reportAssertStack(const char *const file, const unsigned int line, const char *const func, const char *const name, const char *const text) { logger->log("--- Assert: %s --------------------------------------------", name); logger->assertLog("%s:%u: '%s' in function `%s'", file, line, text, func); #ifndef ANDROID #if defined __linux__ || defined __linux reportStack(); #endif // defined __linux__ || defined __linux #endif // ANDROID } void reportLogStack(const char *const file, const unsigned int line, const char *const func) { logger->assertLog("%s:%u: in function `%s'", file, line, func); #ifndef ANDROID #if defined __linux__ || defined __linux reportStack(); #endif // defined __linux__ || defined __linux #endif // ANDROID } void reportStack() { #ifndef ANDROID #if defined __linux__ || defined __linux void *array[15]; const int size = static_cast<int>(backtrace(array, 15)); char **strings = backtrace_symbols(array, size); for (int i = 0; i < size; i++) logger->log1(strings[i]); free(strings); #endif // defined __linux__ || defined __linux #endif // ANDROID } #endif // ENABLE_ASSERTS