Signal2<void, int, const std::string&> logOutput;
int logOutputConsole=1;
+pthread_mutex_t signalLock =
+ PTHREAD_ADAPTIVE_MUTEX_INITIALIZER_NP;
+
void eFatal(const char* fmt, ...)
{
char buf[1024];
va_start(ap, fmt);
vsnprintf(buf, 1024, fmt, ap);
va_end(ap);
+ singleLock s(signalLock);
logOutput(lvlFatal, buf);
fprintf(stderr, "FATAL: %s\n",buf );
#if 0
msg.exec();
}
#endif
-
_exit(0);
}
va_start(ap, fmt);
vsnprintf(buf, 1024, fmt, ap);
va_end(ap);
+ singleLock s(signalLock);
logOutput(lvlDebug, std::string(buf) + "\n");
if (logOutputConsole)
fprintf(stderr, "%s\n", buf);
va_start(ap, fmt);
vsnprintf(buf, 1024, fmt, ap);
va_end(ap);
+ singleLock s(signalLock);
logOutput(lvlDebug, buf);
if (logOutputConsole)
fprintf(stderr, "%s", buf);
va_start(ap, fmt);
vsnprintf(buf, 1024, fmt, ap);
va_end(ap);
+ singleLock s(signalLock);
logOutput(lvlWarning, std::string(buf) + "\n");
if (logOutputConsole)
fprintf(stderr, "%s\n", buf);