mirror of
https://github.com/FEX-Emu/FEX.git
synced 2025-02-08 23:57:05 +00:00
![Ryan Houdek](/assets/img/avatar_default.png)
We never use more than one logging method at a time so this was overengineered for what it is doing. Instead only allow one handler for messages and throw messages each which just is a pointer. Removes a global initializer and an atexit handler being installed
51 lines
1015 B
C++
51 lines
1015 B
C++
// SPDX-License-Identifier: MIT
|
|
/*
|
|
$info$
|
|
tags: glue|log-manager
|
|
$end_info$
|
|
*/
|
|
|
|
#include <FEXCore/Utils/CompilerDefs.h>
|
|
#include <FEXCore/Utils/LogManager.h>
|
|
#include <FEXCore/fextl/fmt.h>
|
|
|
|
namespace LogMan {
|
|
|
|
namespace Throw {
|
|
ThrowHandler Handler {};
|
|
void InstallHandler(ThrowHandler _Handler) {
|
|
Handler = _Handler;
|
|
}
|
|
void UnInstallHandler() {
|
|
Handler = nullptr;
|
|
}
|
|
|
|
void MFmt(const char* fmt, const fmt::format_args& args) {
|
|
if (Handler) {
|
|
auto msg = fextl::fmt::vformat(fmt, args);
|
|
Handler(msg.c_str());
|
|
}
|
|
|
|
FEX_TRAP_EXECUTION;
|
|
}
|
|
} // namespace Throw
|
|
|
|
namespace Msg {
|
|
MsgHandler Handler {};
|
|
void InstallHandler(MsgHandler _Handler) {
|
|
Handler = _Handler;
|
|
}
|
|
void UnInstallHandler() {
|
|
Handler = nullptr;
|
|
}
|
|
|
|
void MFmtImpl(DebugLevels level, const char* fmt, const fmt::format_args& args) {
|
|
if (Handler) {
|
|
const auto msg = fextl::fmt::vformat(fmt, args);
|
|
Handler(level, msg.c_str());
|
|
}
|
|
}
|
|
|
|
} // namespace Msg
|
|
} // namespace LogMan
|