/* */ #include "LogFactory.h" #include "a2io.h" #include "prefs.h" #include "RecoverableException.h" namespace aria2 { std::string LogFactory::filename_ = DEV_NULL; std::shared_ptr LogFactory::logger_; bool LogFactory::consoleOutput_ = true; Logger::LEVEL LogFactory::logLevel_ = Logger::A2_DEBUG; Logger::LEVEL LogFactory::consoleLogLevel_ = Logger::A2_NOTICE; void LogFactory::openLogger(const std::shared_ptr& logger) { if(filename_ != DEV_NULL) { // don't open file DEV_NULL for performance sake. // This avoids costly unecessary message formatting and write. logger->openFile(filename_); } logger->setLogLevel(logLevel_); logger->setConsoleLogLevel(consoleLogLevel_); logger->setConsoleOutput(consoleOutput_); } void LogFactory::reconfigure() { if(logger_) { logger_->closeFile(); try { openLogger(logger_); } catch(RecoverableException& e) { logger_->closeFile(); throw; } } } const std::shared_ptr& LogFactory::getInstance() { if(!logger_) { std::shared_ptr slogger(new Logger()); openLogger(slogger); logger_.swap(slogger); } return logger_; } void LogFactory::setLogFile(const std::string& name) { if(name == "-") { filename_ = DEV_STDOUT; } else if(name == "") { filename_ = DEV_NULL; } else { filename_ = name; } } namespace { Logger::LEVEL toLogLevel(const std::string& level) { if(level == V_DEBUG) { return Logger::A2_DEBUG; } else if(level == V_INFO) { return Logger::A2_INFO; } else if(level == V_NOTICE) { return Logger::A2_NOTICE; } else if(level == V_WARN) { return Logger::A2_WARN; } else if(level == V_ERROR) { return Logger::A2_ERROR; } else { return Logger::A2_NOTICE; } } } // namespace void LogFactory::setLogLevel(Logger::LEVEL level) { logLevel_ = level; } void LogFactory::setLogLevel(const std::string& level) { logLevel_ = toLogLevel(level); } void LogFactory::setConsoleLogLevel(Logger::LEVEL level) { consoleLogLevel_ = level; } void LogFactory::setConsoleLogLevel(const std::string& level) { consoleLogLevel_ = toLogLevel(level); } void LogFactory::release() { logger_.reset(); } } // namespace aria2