33#include <spdlog/logger.h>
34#include <spdlog/spdlog.h>
36#include <pdi/pdi_fwd.h>
37#include <pdi/paraconf_wrapper.h>
45 std::shared_ptr<spdlog::logger> m_logger;
48 std::vector<std::reference_wrapper<Logger>> m_default_pattern_observers;
51 std::vector<std::string> m_pattern_blocks;
54 std::string m_pattern =
"[%T][%n] *** %^%l%$: %v";
57 bool m_pattern_from_config =
false;
63 Logger* m_parent_logger =
nullptr;
74 Logger(
const std::string& logger_name, PC_tree_t config, spdlog::level::level_enum
level = spdlog::level::info);
87 Logger(
Logger& parent_logger,
const std::string& logger_name, PC_tree_t config);
94 void setup(
const std::string& logger_name, PC_tree_t config, spdlog::level::level_enum
level = spdlog::level::info);
101 void setup(
Logger& parent_logger,
const std::string& logger_name, PC_tree_t config);
147 void level(spdlog::level::level_enum log_level);
152 spdlog::level::level_enum
level()
const;
175 template <
typename... Args>
176 void trace(fmt::format_string<Args...> fmt, Args&&... args)
178 m_logger->trace(fmt, std::forward<Args>(args)...);
185 template <
typename... Args>
186 void debug(fmt::format_string<Args...> fmt, Args&&... args)
188 m_logger->debug(fmt, std::forward<Args>(args)...);
195 template <
typename... Args>
196 void info(fmt::format_string<Args...> fmt, Args&&... args)
198 m_logger->info(fmt, std::forward<Args>(args)...);
205 template <
typename... Args>
206 void warn(fmt::format_string<Args...> fmt, Args&&... args)
208 m_logger->warn(fmt, std::forward<Args>(args)...);
215 template <
typename... Args>
216 void error(fmt::format_string<Args...> fmt, Args&&... args)
218 m_logger->error(fmt, std::forward<Args>(args)...);
void error(fmt::format_string< Args... > fmt, Args &&... args)
Writes error level message.
Definition logger.h:216
const std::string & pattern() const
Returns pattern of the logger.
void trace(fmt::format_string< Args... > fmt, Args &&... args)
Writes trace level message.
Definition logger.h:176
Logger()=default
Creates new empty logger.
void setup(Logger &parent_logger, const std::string &logger_name, PC_tree_t config)
Sets up the logger with parent logger.
void level(spdlog::level::level_enum log_level)
Sets logger level.
void default_pattern(const std::string &pattern)
Changes default pattern of the logger (won't be updated if current pattern is from config).
void debug(fmt::format_string< Args... > fmt, Args &&... args)
Writes debug level message.
Definition logger.h:186
void global_pattern(const std::string &pattern)
Changes pattern of the global logger.
Logger(Logger &parent_logger, const std::string &logger_name, PC_tree_t config)
Creates new logger with parent logger.
void evaluate_global_pattern(Context &ctx) const
Evaluate global pattern.
Logger(const std::string &logger_name, PC_tree_t config, spdlog::level::level_enum level=spdlog::level::info)
Creates new logger.
void add_pattern_global_block(const std::string &block)
Add new element to default pattern of the global logger.
void add_pattern_block(const std::string &block)
Add new element to default pattern.
void warn(fmt::format_string< Args... > fmt, Args &&... args)
Writes warning level message.
Definition logger.h:206
void info(fmt::format_string< Args... > fmt, Args &&... args)
Writes info level message.
Definition logger.h:196
spdlog::level::level_enum level() const
Returns level of the logger.
void setup(const std::string &logger_name, PC_tree_t config, spdlog::level::level_enum level=spdlog::level::info)
Sets up the logger.
void pattern(const std::string &pattern)
Changes pattern of the logger.
void evaluate_pattern(Context &ctx) const
Evaluate pattern.
std::shared_ptr< spdlog::logger > real_logger()
Returns real spdlog logger.
Definition array_datatype.h:38