diff options
| author | Mehmet Samet Duman <yongdohyun@projecttick.org> | 2026-04-02 18:51:45 +0300 |
|---|---|---|
| committer | Mehmet Samet Duman <yongdohyun@projecttick.org> | 2026-04-02 18:51:45 +0300 |
| commit | d3261e64152397db2dca4d691a990c6bc2a6f4dd (patch) | |
| tree | fac2f7be638651181a72453d714f0f96675c2b8b /archived/projt-launcher/launcher/launch/LaunchLineRouter.cpp | |
| parent | 31b9a8949ed0a288143e23bf739f2eb64fdc63be (diff) | |
| download | Project-Tick-d3261e64152397db2dca4d691a990c6bc2a6f4dd.tar.gz Project-Tick-d3261e64152397db2dca4d691a990c6bc2a6f4dd.zip | |
NOISSUE add archived projects
Signed-off-by: Mehmet Samet Duman <yongdohyun@projecttick.org>
Diffstat (limited to 'archived/projt-launcher/launcher/launch/LaunchLineRouter.cpp')
| -rw-r--r-- | archived/projt-launcher/launcher/launch/LaunchLineRouter.cpp | 117 |
1 files changed, 117 insertions, 0 deletions
diff --git a/archived/projt-launcher/launcher/launch/LaunchLineRouter.cpp b/archived/projt-launcher/launcher/launch/LaunchLineRouter.cpp new file mode 100644 index 0000000000..4280e749d3 --- /dev/null +++ b/archived/projt-launcher/launcher/launch/LaunchLineRouter.cpp @@ -0,0 +1,117 @@ +// SPDX-License-Identifier: GPL-3.0-only +// SPDX-FileCopyrightText: 2026 Project Tick +// SPDX-FileContributor: Project Tick Team +/* + * ProjT Launcher - Minecraft Launcher + * Copyright (C) 2026 Project Tick + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, version 3. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, write to the Free Software Foundation, + * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + */ + +#include "LaunchLineRouter.hpp" + +#include <QObject> +#include <variant> + +#include "LaunchLogModel.hpp" + +namespace projt::launch +{ + QString LaunchLineRouter::applyRedactions(QString input, const QMap<QString, QString>& redactions) const + { + for (auto it = redactions.begin(); it != redactions.end(); ++it) + { + input.replace(it.key(), it.value()); + } + return input; + } + + bool LaunchLineRouter::parseStructured(const QString& line, + MessageLevel::Enum level, + LaunchLogModel& model, + const QMap<QString, QString>& redactions) + { + projt::logs::LogEventParser* parser = nullptr; + switch (level) + { + case MessageLevel::StdErr: parser = &m_stderrParser; break; + case MessageLevel::StdOut: parser = &m_stdoutParser; break; + default: return false; + } + + parser->pushLine(line); + auto items = parser->drainAvailable(); + if (auto err = parser->lastError(); err.has_value()) + { + model.append(MessageLevel::Error, QObject::tr("Log parser error: %1").arg(err.value().message)); + return false; + } + + if (items.isEmpty()) + { + return true; + } + + for (const auto& item : items) + { + if (std::holds_alternative<projt::logs::LogEventParser::LogRecord>(item)) + { + auto entry = std::get<projt::logs::LogEventParser::LogRecord>(item); + auto msg = QString("[%1] [%2/%3] [%4]: %5") + .arg(entry.timestamp.toString("HH:mm:ss")) + .arg(entry.thread) + .arg(entry.levelText) + .arg(entry.logger) + .arg(entry.message); + msg = applyRedactions(msg, redactions); + model.append(entry.level, msg); + continue; + } + if (std::holds_alternative<projt::logs::LogEventParser::RawLine>(item)) + { + auto msg = std::get<projt::logs::LogEventParser::RawLine>(item).text; + auto resolved = projt::logs::LogEventParser::guessLevelFromLine(msg, model.previousLevel()); + msg = applyRedactions(msg, redactions); + model.append(resolved, msg); + } + } + + return true; + } + + void LaunchLineRouter::routeLine(QString line, + MessageLevel::Enum defaultLevel, + LaunchLogModel& model, + const QMap<QString, QString>& redactions) + { + if (parseStructured(line, defaultLevel, model, redactions)) + { + return; + } + + auto embedded = MessageLevel::fromLine(line); + if (embedded != MessageLevel::Unknown) + { + defaultLevel = embedded; + } + + if (defaultLevel == MessageLevel::Unknown) + { + defaultLevel = projt::logs::LogEventParser::guessLevelFromLine(line, model.previousLevel()); + } + + line = applyRedactions(line, redactions); + model.append(defaultLevel, line); + } +} // namespace projt::launch |
