mirror of
https://github.com/k4yt3x/video2x.git
synced 2025-01-14 19:59:23 +00:00
feat(logger): improve logger initialization
Signed-off-by: k4yt3x <i@k4yt3x.com>
This commit is contained in:
parent
f3999a431c
commit
7b8e186207
@ -21,7 +21,7 @@ class LIBVIDEO2X_API LoggerManager {
|
|||||||
|
|
||||||
std::shared_ptr<spdlog::logger> logger();
|
std::shared_ptr<spdlog::logger> logger();
|
||||||
|
|
||||||
void reconfigure_logger(
|
bool reconfigure_logger(
|
||||||
const std::string &logger_name,
|
const std::string &logger_name,
|
||||||
const std::vector<spdlog::sink_ptr> &sinks,
|
const std::vector<spdlog::sink_ptr> &sinks,
|
||||||
const std::string &pattern = "%+"
|
const std::string &pattern = "%+"
|
||||||
@ -35,7 +35,7 @@ class LIBVIDEO2X_API LoggerManager {
|
|||||||
private:
|
private:
|
||||||
LoggerManager();
|
LoggerManager();
|
||||||
|
|
||||||
std::shared_ptr<spdlog::logger> logger_;
|
std::shared_ptr<spdlog::logger> logger_ = nullptr;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace logger_manager
|
} // namespace logger_manager
|
||||||
|
@ -48,9 +48,9 @@ namespace logger_manager {
|
|||||||
LoggerManager::LoggerManager() {
|
LoggerManager::LoggerManager() {
|
||||||
auto console_sink = std::make_shared<spdlog::sinks::stdout_color_sink_mt>();
|
auto console_sink = std::make_shared<spdlog::sinks::stdout_color_sink_mt>();
|
||||||
console_sink->set_pattern("%+");
|
console_sink->set_pattern("%+");
|
||||||
|
console_sink->set_level(spdlog::level::info);
|
||||||
logger_ = std::make_shared<spdlog::logger>("video2x", console_sink);
|
logger_ = std::make_shared<spdlog::logger>("video2x", console_sink);
|
||||||
spdlog::register_logger(logger_);
|
spdlog::register_logger(logger_);
|
||||||
logger_->set_level(spdlog::level::info);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
LoggerManager &LoggerManager::instance() {
|
LoggerManager &LoggerManager::instance() {
|
||||||
@ -62,31 +62,36 @@ std::shared_ptr<spdlog::logger> LoggerManager::logger() {
|
|||||||
return logger_;
|
return logger_;
|
||||||
}
|
}
|
||||||
|
|
||||||
void LoggerManager::reconfigure_logger(
|
bool LoggerManager::reconfigure_logger(
|
||||||
const std::string &logger_name,
|
const std::string &logger_name,
|
||||||
const std::vector<spdlog::sink_ptr> &sinks,
|
const std::vector<spdlog::sink_ptr> &sinks,
|
||||||
const std::string &pattern
|
const std::string &pattern
|
||||||
) {
|
) {
|
||||||
if (!sinks.empty()) {
|
if (logger_name.empty() || sinks.empty()) {
|
||||||
// If a logger with the same name exists, remove it first
|
return false;
|
||||||
auto old_logger = spdlog::get(logger_name);
|
|
||||||
if (old_logger) {
|
|
||||||
spdlog::drop(logger_name);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create a new logger with the given name, sinks, and pattern
|
// Create a new logger with the given name, sinks, and pattern
|
||||||
auto new_logger = std::make_shared<spdlog::logger>(logger_name, sinks.begin(), sinks.end());
|
std::shared_ptr<spdlog::logger> new_logger =
|
||||||
|
std::make_shared<spdlog::logger>(logger_name, sinks.begin(), sinks.end());
|
||||||
new_logger->set_pattern(pattern);
|
new_logger->set_pattern(pattern);
|
||||||
|
|
||||||
// Maintain the log level from the previous logger
|
// Maintain the log level from the previous logger
|
||||||
if (logger_) {
|
if (logger_ != nullptr) {
|
||||||
new_logger->set_level(logger_->level());
|
new_logger->set_level(logger_->level());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// If a logger with the same name exists, remove it first
|
||||||
|
std::shared_ptr<spdlog::logger> old_logger = spdlog::get(logger_name);
|
||||||
|
if (old_logger != nullptr) {
|
||||||
|
spdlog::drop(logger_name);
|
||||||
|
logger_ = nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
// Replace the internal logger_ member and register the new one
|
// Replace the internal logger_ member and register the new one
|
||||||
logger_ = new_logger;
|
logger_ = new_logger;
|
||||||
spdlog::register_logger(logger_);
|
spdlog::register_logger(logger_);
|
||||||
}
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool LoggerManager::set_log_level(const std::string &level_str) {
|
bool LoggerManager::set_log_level(const std::string &level_str) {
|
||||||
|
@ -56,9 +56,12 @@ int main(int argc, char **argv) {
|
|||||||
// Initialize newline-safe logger with custom formatting pattern
|
// Initialize newline-safe logger with custom formatting pattern
|
||||||
std::shared_ptr<newline_safe_sink> logger_sink = std::make_shared<newline_safe_sink>();
|
std::shared_ptr<newline_safe_sink> logger_sink = std::make_shared<newline_safe_sink>();
|
||||||
std::vector<spdlog::sink_ptr> sinks = {logger_sink};
|
std::vector<spdlog::sink_ptr> sinks = {logger_sink};
|
||||||
video2x::logger_manager::LoggerManager::instance().reconfigure_logger(
|
if (!video2x::logger_manager::LoggerManager::instance().reconfigure_logger(
|
||||||
"video2x", sinks, "[%Y-%m-%d %H:%M:%S] [%^%l%$] %v"
|
"video2x", sinks, "[%Y-%m-%d %H:%M:%S] [%^%l%$] %v"
|
||||||
);
|
)) {
|
||||||
|
std::cerr << "Error: Failed to configure logger." << std::endl;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
// Initialize argument and configuration structs
|
// Initialize argument and configuration structs
|
||||||
Arguments arguments;
|
Arguments arguments;
|
||||||
|
Loading…
Reference in New Issue
Block a user