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