mirror of
https://github.com/PrismLauncher/PrismLauncher.git
synced 2025-08-04 03:47:57 -04:00
72 lines
2.1 KiB
C++
72 lines
2.1 KiB
C++
#include "MessageLevel.h"
|
|
|
|
MessageLevel::Enum MessageLevel::getLevel(const QString& levelName)
|
|
{
|
|
QString name = levelName.toUpper();
|
|
if (name == "LAUNCHER")
|
|
return MessageLevel::Launcher;
|
|
else if (name == "TRACE")
|
|
return MessageLevel::Trace;
|
|
else if (name == "DEBUG")
|
|
return MessageLevel::Debug;
|
|
else if (name == "INFO")
|
|
return MessageLevel::Info;
|
|
else if (name == "MESSAGE")
|
|
return MessageLevel::Message;
|
|
else if (name == "WARNING" || name == "WARN")
|
|
return MessageLevel::Warning;
|
|
else if (name == "ERROR" || name == "CRITICAL")
|
|
return MessageLevel::Error;
|
|
else if (name == "FATAL")
|
|
return MessageLevel::Fatal;
|
|
// Skip PrePost, it's not exposed to !![]!
|
|
// Also skip StdErr and StdOut
|
|
else
|
|
return MessageLevel::Unknown;
|
|
}
|
|
|
|
MessageLevel::Enum MessageLevel::getLevel(QtMsgType type)
|
|
{
|
|
switch (type) {
|
|
case QtDebugMsg:
|
|
return MessageLevel::Debug;
|
|
case QtInfoMsg:
|
|
return MessageLevel::Info;
|
|
case QtWarningMsg:
|
|
return MessageLevel::Warning;
|
|
case QtCriticalMsg:
|
|
return MessageLevel::Error;
|
|
case QtFatalMsg:
|
|
return MessageLevel::Fatal;
|
|
default:
|
|
return MessageLevel::Unknown;
|
|
}
|
|
}
|
|
|
|
MessageLevel::Enum MessageLevel::fromLine(QString& line)
|
|
{
|
|
// Level prefix
|
|
int endmark = line.indexOf("]!");
|
|
if (line.startsWith("!![") && endmark != -1) {
|
|
auto level = MessageLevel::getLevel(line.left(endmark).mid(3));
|
|
line = line.mid(endmark + 2);
|
|
return level;
|
|
}
|
|
return MessageLevel::Unknown;
|
|
}
|
|
|
|
MessageLevel::Enum MessageLevel::fromLauncherLine(QString& line)
|
|
{
|
|
// Level prefix
|
|
int startMark = 0;
|
|
while (startMark < line.size() && (line[startMark].isDigit() || line[startMark].isSpace() || line[startMark] == '.'))
|
|
++startMark;
|
|
int endmark = line.indexOf(":");
|
|
if (startMark < line.size() && endmark != -1) {
|
|
auto level = MessageLevel::getLevel(line.left(endmark).mid(startMark));
|
|
line = line.mid(endmark + 2);
|
|
return level;
|
|
}
|
|
return MessageLevel::Unknown;
|
|
}
|