1

我正在编写如下函数:

bool abc::GetLoggingStatus() {
    //true or false is returned
    int value;
    if (regKey->HasValue("LoggingStatus")) {
        regKey->QueryValue("LoggingStatus", &value);
        if (value == 1)
            return true; //no logging possible
        else
            return false;
    }
    regKey->SetValue("LoggingStatus", 1);
    return true;
}

日志记录级别定义为:

typedef enum {
    Entry,
    Exit,
    Debug,
    Warning,
    Notification,
    Error
} TYPE;

如果我选择 1 需要什么,则必须显示日志记录级别,即调试、错误...在 regedit 中,如果为 0,则不应显示任何内容并禁用日志记录。

4

1 回答 1

3

您无法在 regedit 中创建下拉菜单,但您可以创建一个名为LoggingLevel. LoggingStatus如果为 0 ,则忽略此条目。是LoggingLevel定义级别的字符串。

如果您想将此字符串转换回枚举,最简单的方法是创建一个从字符串到您的 Enum 类型的映射:

std::map<std::string, TYPE> typeMap;
typeMap["Warning"] = Warning;
...

在您的代码中,您查询日志记录级别:

char* level;
regKey->QueryValue("LoggingLevel", level);
TYPE theLevel = typeMap[level];

当然,您需要进行适当的错误检查。

编辑

您应该添加两个函数来获取日志设置,shouldLog()以及getLevel(). 日志函数将如下所示:

void log(Logger* logger, TYPE type, string sClassName, string sMethodName, string sMessage = "") { 
if (!logger || !abc::shouldLog()) {
   return;
}


TYPE curLevel = abc::getLevel();
bool shouldLog = false;

if (type == Warning && (curLevel == All || curLevel == Warning) ...) {
  shouldLog = true;
}

if (shouldLog) {logger->WriteEntry(sClassName, sMethodName); }

}

如果您想避免复杂的 if 结构,您还可以尝试将枚举映射到一个值并进行比较。例如,Warning = 1 和 ALL = 0。然后您可以检查是否curLevel < type要查看记录器是否应该记录。

于 2012-08-14T10:09:37.320 回答