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:
parent
d2c7179cd0
commit
1e6ed8db68
1 changed files with 12 additions and 6 deletions
|
@ -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();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue