1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97
|
#include "log-helper.hpp"
#include "obs-module-helper.hpp"
#include <map>
#include <obs-data.h>
#include <QComboBox>
#include <string>
namespace advss {
static LogLevel logLevel = LogLevel::DEFAULT;
bool VerboseLoggingEnabled()
{
return logLevel == LogLevel::VERBOSE;
}
bool ActionLoggingEnabled()
{
return logLevel == LogLevel::LOG_ACTION || VerboseLoggingEnabled();
}
bool MacroLoggingEnabled()
{
return logLevel == LogLevel::LOG_MACRO || ActionLoggingEnabled();
}
bool LoggingEnabled()
{
return logLevel != LogLevel::DISABLE;
}
void SetLogLevel(LogLevel newLogLevel)
{
logLevel = newLogLevel;
}
LogLevel GetLogLevel()
{
return logLevel;
}
void SaveLogLevel(void *data)
{
auto obj = static_cast<obs_data_t *>(data);
obs_data_set_int(obj, "logLevel", static_cast<int>(logLevel));
obs_data_set_int(obj, "logLevelVersion", 1);
}
void LoadLogLevel(void *data)
{
auto obj = static_cast<obs_data_t *>(data);
logLevel = static_cast<LogLevel>(obs_data_get_int(obj, "logLevel"));
if (obs_data_get_int(obj, "logLevelVersion") < 1) {
enum OldLogLevel { DEFAULT, LOG_ACTION, VERBOSE };
OldLogLevel oldLogLevel = static_cast<OldLogLevel>(
obs_data_get_int(obj, "logLevel"));
switch (oldLogLevel) {
case DEFAULT:
logLevel = LogLevel::DEFAULT;
break;
case LOG_ACTION:
logLevel = LogLevel::LOG_ACTION;
break;
case VERBOSE:
logLevel = LogLevel::VERBOSE;
break;
default:
break;
}
}
}
void PopulateLogLevelSelection(void *sel)
{
auto selection = static_cast<QComboBox *>(sel);
static const std::map<LogLevel, std::string> logLevels = {
{LogLevel::DISABLE,
"AdvSceneSwitcher.generalTab.generalBehavior.logLevel.disable"},
{LogLevel::DEFAULT,
"AdvSceneSwitcher.generalTab.generalBehavior.logLevel.default"},
{LogLevel::LOG_MACRO,
"AdvSceneSwitcher.generalTab.generalBehavior.logLevel.logMacro"},
{LogLevel::LOG_ACTION,
"AdvSceneSwitcher.generalTab.generalBehavior.logLevel.logAction"},
{LogLevel::VERBOSE,
"AdvSceneSwitcher.generalTab.generalBehavior.logLevel.verbose"},
};
selection->clear();
for (const auto &[value, name] : logLevels) {
selection->addItem(obs_module_text(name.c_str()),
static_cast<int>(value));
}
}
} // namespace advss
|