我正在写一个函数如下:
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则不显示任何内容并禁用日志记录。
答案 0 :(得分: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
以查看记录器是否应该记录。