#include "core/stdafx.h" #include "core/logdef.h" std::shared_ptr g_TermLogger; std::shared_ptr g_ImGuiLogger; //############################################################################# // SPDLOG INIT //############################################################################# void SpdLog_Init(void) { static bool bInitialized = false; if (bInitialized) { Assert(bInitialized, "'SpdLog_Init()' has already been called."); return; } #ifndef NETCONSOLE g_LogSessionDirectory = fmt::format("platform\\logs\\{:s}", g_ProcessTimestamp); /************************ * IMGUI LOGGER SETUP * ************************/ { g_ImGuiLogger = std::make_shared("game_console", g_LogSink); spdlog::register_logger(g_ImGuiLogger); // in-game console logger. g_ImGuiLogger->set_pattern("[0.000] %v"); g_ImGuiLogger->set_level(spdlog::level::trace); } #endif // !NETCONSOLE /************************ * WINDOWS LOGGER SETUP * ************************/ { #ifdef NETCONSOLE g_TermLogger = spdlog::default_logger(); #else g_TermLogger = spdlog::stdout_logger_mt("win_console"); #endif // NETCONSOLE // Determine if user wants ansi-color logging in the terminal. if (g_svCmdLine.find("-ansicolor") != string::npos) { g_TermLogger->set_pattern("[0.000] %v\u001b[0m"); g_bSpdLog_UseAnsiClr = true; } else { g_TermLogger->set_pattern("[0.000] %v"); } //g_TermLogger->set_level(spdlog::level::trace); } #ifndef NETCONSOLE spdlog::set_default_logger(g_TermLogger); // Set as default. SpdLog_Create(); #endif // !NETCONSOLE spdlog::set_level(spdlog::level::trace); bInitialized = true; } void SpdLog_Create() { /************************ * ROTATE LOGGER SETUP * ************************/ spdlog::rotating_logger_mt("squirrel_re(warning)" , fmt::format("{:s}\\{:s}", g_LogSessionDirectory, "script_warning.log"), SPDLOG_MAX_SIZE, SPDLOG_NUM_FILE)->set_pattern("[%Y-%m-%d %H:%M:%S.%e] %v"); spdlog::rotating_logger_mt("squirrel_re" , fmt::format("{:s}\\{:s}", g_LogSessionDirectory, "script.log"), SPDLOG_MAX_SIZE, SPDLOG_NUM_FILE)->set_pattern("[%Y-%m-%d %H:%M:%S.%e] %v"); spdlog::rotating_logger_mt("sdk" , fmt::format("{:s}\\{:s}", g_LogSessionDirectory, "message.log"), SPDLOG_MAX_SIZE, SPDLOG_NUM_FILE)->set_pattern("[%Y-%m-%d %H:%M:%S.%e] %v"); spdlog::rotating_logger_mt("sdk(warning)" , fmt::format("{:s}\\{:s}", g_LogSessionDirectory, "warning.log"), SPDLOG_MAX_SIZE, SPDLOG_NUM_FILE)->set_pattern("[%Y-%m-%d %H:%M:%S.%e] %v"); spdlog::rotating_logger_mt("sdk(error)" , fmt::format("{:s}\\{:s}", g_LogSessionDirectory, "error.log"), SPDLOG_MAX_SIZE, SPDLOG_NUM_FILE)->set_pattern("[%Y-%m-%d %H:%M:%S.%e] %v"); spdlog::rotating_logger_mt("net_trace" , fmt::format("{:s}\\{:s}", g_LogSessionDirectory, "net_trace.log"), SPDLOG_MAX_SIZE, SPDLOG_NUM_FILE)->set_pattern("[%Y-%m-%d %H:%M:%S.%e] %v"); #ifndef DEDICATED spdlog::rotating_logger_mt("netconsole" , fmt::format("{:s}\\{:s}", g_LogSessionDirectory, "netconsole.log"), SPDLOG_MAX_SIZE, SPDLOG_NUM_FILE)->set_pattern("[%Y-%m-%d %H:%M:%S.%e] %v"); #endif // !DEDICATED spdlog::rotating_logger_mt("filesystem" , fmt::format("{:s}\\{:s}", g_LogSessionDirectory, "filesystem.log"), SPDLOG_MAX_SIZE, SPDLOG_NUM_FILE)->set_pattern("[%Y-%m-%d %H:%M:%S.%e] %v"); } //############################################################################# // SPDLOG POST INIT //############################################################################# void SpdLog_PostInit() { #ifndef NETCONSOLE spdlog::flush_every(std::chrono::seconds(5)); // Flush buffers every 5 seconds for every logger. g_ImGuiLogger->set_pattern("%v"); #endif // !NETCONSOLE if (g_svCmdLine.find("-ansicolor") != string::npos) { g_TermLogger->set_pattern("%v\u001b[0m"); g_bSpdLog_UseAnsiClr = true; } else { g_TermLogger->set_pattern("%v"); } g_bSpdLog_PostInit = true; } //############################################################################# // SPDLOG SHUTDOWN //############################################################################# void SpdLog_Shutdown() { spdlog::shutdown(); }