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.
*/
// 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 *
getLoggingClasses ()
{
sgDebugClass classes = logbuf::get_log_classes();
static string result;
result = "";
loggingResult.clear();
for (int i = 0; log_class_mappings[i].c != SG_UNDEFD; i++) {
if ((classes&log_class_mappings[i].c) > 0) {
if (!result.empty())
result += '|';
result += log_class_mappings[i].name;
if (!loggingResult.empty())
loggingResult += '|';
loggingResult += log_class_mappings[i].name;
}
}
return result.c_str();
return loggingResult.c_str();
}