#include "zlog.h" #include #include #include #include namespace zlog { zloger zlog; zloger::zloger() { auto console_sink = std::make_shared(); console_sink->set_level(spdlog::level::trace); console_sink->set_pattern("[%Y-%m-%d %H:%M:%S][%s:%#] %-8l %^%v%$"); auto file_sink = std::make_shared("logs/zengine.log", true); file_sink->set_level(spdlog::level::trace); //file_sink->set_pattern("[%Y-%m-%d %H:%M:%S][%s:%#] %-8l %^%v%$"); const spdlog::sinks_init_list sink_list = { console_sink, file_sink }; spdlog::init_thread_pool(8192, 1); m_logger = std::make_shared("zlogger", sink_list.begin(), sink_list.end(), spdlog::thread_pool(), spdlog::async_overflow_policy::block); m_logger->set_level(spdlog::level::trace); m_logger->set_pattern("[%Y-%m-%d %H:%M:%S][%s:%#] %-8l %^%v%$"); spdlog::register_logger(m_logger); } zloger::~zloger() { m_logger->flush(); spdlog::drop_all(); } }