File: log-helper.cpp

package info (click to toggle)
obs-advanced-scene-switcher 1.32.8-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 43,492 kB
  • sloc: xml: 297,593; cpp: 147,875; python: 387; sh: 280; ansic: 170; makefile: 33
file content (97 lines) | stat: -rw-r--r-- 2,229 bytes parent folder | download
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