mirror of
https://git.eden-emu.dev/eden-emu/eden
synced 2026-04-15 06:48:55 +02:00
- our logging code was bigger than spdlog itself, why???? just keep it simple - fix issues when logging before logging system is even started - removes the "initialized logging twice" issue - removes uneeded indirection in file logging - uses direct formatting instead of jumping hoopla-around the fmt::format() ressult - code duplication and dead code removal as usual I did explore dup2() but I think it's not worth the hassle I did try `fwopen()` but it's better if things are just kept as-is. there is a lot of noise because I removed a bunch of redundant files on logging and just put everything in one file now normally this wouldn't be a good idea, however consider: the complexity of logging; it's less than 500 lines... does it really need a whole subsystem?!?!?! ITS JUST LOGGING Signed-off-by: lizzie <lizzie@eden-emu.dev> Reviewed-on: https://git.eden-emu.dev/eden-emu/eden/pulls/3688 Reviewed-by: crueter <crueter@eden-emu.dev> Reviewed-by: DraVee <chimera@dravee.dev> Reviewed-by: CamilleLaVey <camillelavey99@gmail.com> Co-authored-by: lizzie <lizzie@eden-emu.dev> Co-committed-by: lizzie <lizzie@eden-emu.dev>
53 lines
1.7 KiB
C++
53 lines
1.7 KiB
C++
// SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
|
|
// SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
// SPDX-FileCopyrightText: Copyright 2018 yuzu Emulator Project
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
|
|
#ifdef _WIN32
|
|
#include <windows.h>
|
|
|
|
#include <wincon.h>
|
|
#endif
|
|
|
|
#include "common/logging.h"
|
|
#include "yuzu/debugger/console.h"
|
|
#include "qt_common/config/uisettings.h"
|
|
#include "yuzu/debugger/console.h"
|
|
|
|
namespace Debugger {
|
|
void ToggleConsole() {
|
|
static bool console_shown = false;
|
|
if (console_shown == UISettings::values.show_console.GetValue()) {
|
|
return;
|
|
} else {
|
|
console_shown = UISettings::values.show_console.GetValue();
|
|
}
|
|
|
|
using namespace Common::Log;
|
|
#if defined(_WIN32) && !defined(_DEBUG)
|
|
FILE* temp;
|
|
if (UISettings::values.show_console) {
|
|
if (AllocConsole()) {
|
|
// The first parameter for freopen_s is a out parameter, so we can just ignore it
|
|
freopen_s(&temp, "CONIN$", "r", stdin);
|
|
freopen_s(&temp, "CONOUT$", "w", stdout);
|
|
freopen_s(&temp, "CONOUT$", "w", stderr);
|
|
SetConsoleOutputCP(65001);
|
|
SetColorConsoleBackendEnabled(true);
|
|
}
|
|
} else {
|
|
if (FreeConsole()) {
|
|
// In order to close the console, we have to also detach the streams on it.
|
|
// Just redirect them to NUL if there is no console window
|
|
SetColorConsoleBackendEnabled(false);
|
|
freopen_s(&temp, "NUL", "r", stdin);
|
|
freopen_s(&temp, "NUL", "w", stdout);
|
|
freopen_s(&temp, "NUL", "w", stderr);
|
|
}
|
|
}
|
|
#else
|
|
SetColorConsoleBackendEnabled(UISettings::values.show_console.GetValue());
|
|
#endif
|
|
}
|
|
} // namespace Debugger
|