From: Andreas Monzner Date: Fri, 15 Dec 2006 16:16:49 +0000 (+0000) Subject: fix lock, fix non working ASSERT when DEBUG is not defined X-Git-Tag: 2.6.0~2586 X-Git-Url: https://git.cweiske.de/enigma2.git/commitdiff_plain/dc4073de1957503fcd2a7eed055c55a2265d1212 fix lock, fix non working ASSERT when DEBUG is not defined --- diff --git a/lib/base/eerror.cpp b/lib/base/eerror.cpp index a8411879..2182df49 100644 --- a/lib/base/eerror.cpp +++ b/lib/base/eerror.cpp @@ -1,4 +1,5 @@ #include +#include #include #include #include @@ -6,8 +7,6 @@ #include -// #include - #ifdef MEMLEAK_CHECK AllocList *allocList; pthread_mutex_t memLock = @@ -67,16 +66,12 @@ void DumpUnfreed() printf("Total Unfreed: %d bytes\n", totalSize); fflush(stdout); }; -#else - #include #endif -int infatal=0; - Signal2 logOutput; -int logOutputConsole=1; +int logOutputConsole=0; -pthread_mutex_t signalLock = +static pthread_mutex_t DebugLock = PTHREAD_ADAPTIVE_MUTEX_INITIALIZER_NP; void eFatal(const char* fmt, ...) @@ -86,18 +81,9 @@ void eFatal(const char* fmt, ...) va_start(ap, fmt); vsnprintf(buf, 1024, fmt, ap); va_end(ap); - singleLock s(signalLock); + singleLock s(DebugLock); logOutput(lvlFatal, buf); fprintf(stderr, "FATAL: %s\n",buf ); -#if 0 - if (!infatal) - { - infatal=1; - eMessageBox msg(buf, "FATAL ERROR", eMessageBox::iconError|eMessageBox::btOK); - msg.show(); - msg.exec(); - } -#endif _exit(0); } @@ -109,7 +95,7 @@ void eDebug(const char* fmt, ...) va_start(ap, fmt); vsnprintf(buf, 1024, fmt, ap); va_end(ap); - singleLock s(signalLock); + singleLock s(DebugLock); logOutput(lvlDebug, std::string(buf) + "\n"); if (logOutputConsole) fprintf(stderr, "%s\n", buf); @@ -122,7 +108,7 @@ void eDebugNoNewLine(const char* fmt, ...) va_start(ap, fmt); vsnprintf(buf, 1024, fmt, ap); va_end(ap); - singleLock s(signalLock); + singleLock s(DebugLock); logOutput(lvlDebug, buf); if (logOutputConsole) fprintf(stderr, "%s", buf); @@ -135,19 +121,20 @@ void eWarning(const char* fmt, ...) va_start(ap, fmt); vsnprintf(buf, 1024, fmt, ap); va_end(ap); - singleLock s(signalLock); + singleLock s(DebugLock); logOutput(lvlWarning, std::string(buf) + "\n"); if (logOutputConsole) fprintf(stderr, "%s\n", buf); } -#endif // DEBUG void ePythonOutput(const char *string) { + singleLock s(DebugLock); logOutput(lvlWarning, string); if (logOutputConsole) fwrite(string, 1, strlen(string), stderr); } +#endif // DEBUG void eWriteCrashdump() { diff --git a/lib/base/eerror.h b/lib/base/eerror.h index e7c33a0b..2d4e9790 100644 --- a/lib/base/eerror.h +++ b/lib/base/eerror.h @@ -135,13 +135,17 @@ enum { lvlDebug=1, lvlWarning=2, lvlFatal=4 }; inline void eWarning(const char* fmt, ...) { } - #define ASSERT(x) do { } while (0) + #define ASSERT(x) do { x; } while (0) #endif //DEBUG void eWriteCrashdump(); #endif // SWIG -void ePythonOutput(const char *); +#ifndef DEBUG +inline void ePythonOutput(const char *) +{ +} +#endif #endif // __E_ERROR__