mirror of
https://github.com/kunkundi/crossdesk.git
synced 2025-10-28 20:06:14 +08:00
65 lines
1.6 KiB
C++
65 lines
1.6 KiB
C++
#include "rd_log.h"
|
|
|
|
#include <atomic>
|
|
#include <filesystem>
|
|
|
|
namespace crossdesk {
|
|
|
|
namespace {
|
|
|
|
std::string g_log_dir = "logs";
|
|
std::once_flag g_logger_once_flag;
|
|
std::shared_ptr<spdlog::logger> g_logger;
|
|
std::atomic<bool> g_logger_created{false};
|
|
|
|
} // namespace
|
|
|
|
void InitLogger(const std::string& log_dir) {
|
|
if (g_logger_created.load()) {
|
|
LOG_WARN(
|
|
"InitLogger called after logger initialized. Ignoring log_dir: {}, "
|
|
"using previous log_dir: {}",
|
|
log_dir, g_log_dir);
|
|
return;
|
|
}
|
|
|
|
g_log_dir = log_dir;
|
|
}
|
|
|
|
std::shared_ptr<spdlog::logger> get_logger() {
|
|
std::call_once(g_logger_once_flag, []() {
|
|
g_logger_created.store(true);
|
|
|
|
std::error_code ec;
|
|
std::filesystem::create_directories(g_log_dir, ec);
|
|
|
|
auto now = std::chrono::system_clock::now() + std::chrono::hours(8);
|
|
auto now_time = std::chrono::system_clock::to_time_t(now);
|
|
|
|
std::tm tm_info;
|
|
#ifdef _WIN32
|
|
gmtime_s(&tm_info, &now_time);
|
|
#else
|
|
gmtime_r(&now_time, &tm_info);
|
|
#endif
|
|
|
|
std::stringstream ss;
|
|
ss << LOGGER_NAME;
|
|
ss << std::put_time(&tm_info, "-%Y%m%d-%H%M%S.log");
|
|
|
|
std::string filename = g_log_dir + "/" + ss.str();
|
|
|
|
std::vector<spdlog::sink_ptr> sinks;
|
|
sinks.push_back(std::make_shared<spdlog::sinks::stdout_color_sink_mt>());
|
|
sinks.push_back(std::make_shared<spdlog::sinks::rotating_file_sink_mt>(
|
|
filename, 5 * 1024 * 1024, 3));
|
|
|
|
g_logger = std::make_shared<spdlog::logger>(LOGGER_NAME, sinks.begin(),
|
|
sinks.end());
|
|
g_logger->flush_on(spdlog::level::info);
|
|
spdlog::register_logger(g_logger);
|
|
});
|
|
|
|
return g_logger;
|
|
}
|
|
} // namespace crossdesk
|