mirror of
https://git.eden-emu.dev/eden-emu/eden
synced 2026-04-10 20:38:57 +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>
35 lines
878 B
C++
35 lines
878 B
C++
// SPDX-FileCopyrightText: Copyright 2026 Eden Emulator Project
|
|
// SPDX-License-Identifier: GPL-3.0-or-later
|
|
// SPDX-FileCopyrightText: Copyright 2021 yuzu Emulator Project
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
|
|
#include "common/assert.h"
|
|
#include "common/common_funcs.h"
|
|
#include "common/logging.h"
|
|
#include "common/settings.h"
|
|
|
|
#ifdef _MSC_VER
|
|
extern "C" {
|
|
__declspec(dllimport) void __stdcall DebugBreak(void);
|
|
}
|
|
#endif
|
|
void AssertFailSoftImpl() {
|
|
if (Settings::values.use_debug_asserts) {
|
|
Common::Log::Stop();
|
|
#ifndef _MSC_VER
|
|
# if defined(ARCHITECTURE_x86_64)
|
|
__asm__ __volatile__("int $3");
|
|
# elif defined(ARCHITECTURE_arm64)
|
|
__asm__ __volatile__("brk #0");
|
|
# else
|
|
exit(1);
|
|
# endif
|
|
#else // POSIX ^^^ _MSC_VER vvv
|
|
DebugBreak();
|
|
#endif
|
|
}
|
|
}
|
|
void AssertFatalImpl() {
|
|
Common::Log::Stop();
|
|
std::abort();
|
|
}
|