1
0
Fork 0

Move getLoggingClasses() result buffer to file level.

Getting it out of the function fixes some corruption problems at program exit.
This commit is contained in:
Tim Moore 2009-12-30 17:34:58 +01:00
parent d2c7179cd0
commit 1e6ed8db68

View file

@ -85,20 +85,26 @@ LogClassMapping log_class_mappings [] = {
/** /**
* Get the logging classes. * Get the logging classes.
*/ */
// XXX Making the result buffer be global is a band-aid that hopefully
// delays its destruction 'til after its last use.
namespace
{
string loggingResult;
}
static const char * static const char *
getLoggingClasses () getLoggingClasses ()
{ {
sgDebugClass classes = logbuf::get_log_classes(); sgDebugClass classes = logbuf::get_log_classes();
static string result; loggingResult.clear();
result = "";
for (int i = 0; log_class_mappings[i].c != SG_UNDEFD; i++) { for (int i = 0; log_class_mappings[i].c != SG_UNDEFD; i++) {
if ((classes&log_class_mappings[i].c) > 0) { if ((classes&log_class_mappings[i].c) > 0) {
if (!result.empty()) if (!loggingResult.empty())
result += '|'; loggingResult += '|';
result += log_class_mappings[i].name; loggingResult += log_class_mappings[i].name;
} }
} }
return result.c_str(); return loggingResult.c_str();
} }