-
Notifications
You must be signed in to change notification settings - Fork 136
Logger
tacopie provides a flexible way to setup logging.
By default, the library logs nothing. However, it is possible to set a logger of your choice (either provided by the library or a custom one).
First of all, you have to enable logging by defining the appropriate CMake variable.
Please refer to this part of the wiki.
tacopie::active_logger is the variable that contains the instance of the current logger.
active_logger is defined as follows: extern std::unique_ptr<logger_iface> active_logger, within includes/tacopie/logger.hpp.
This variable can be reset to store the instance of your logger.
Please note that:
- Setting and getting the value of
active_loggeris not thread_safe. Thus, it is preferable to access and modifyactive_loggerbefore usingcpp_redisinside your program. - By default,
active_loggeris set tonullptr, meaning that no logger is used.
tacopie provides a default logger: tacopie::logger.
You can use it by using this line of code:
tacopie::active_logger = std::unique_ptr<tacopie::logger>(new tacopie::logger);Default logger supports different log_level to filter what you want to see. By default, the log_level is set to info, but can be changed using the constructor parameter:
tacopie::active_logger = std::unique_ptr<cpp_http_server::logger>(new tacopie::logger(tacopie::logger::log_level::debug));The following levels are available:
enum class log_level {
error = 0,
warn = 1,
info = 2,
debug = 3
};This logger uses a mutex to provide clean output in the multithreaded context of the library. This is really useful for debug and reporting issues, but it might not be what you are looking for if your primary concern is performance.
You can create and use your custom logger.
tacopie provides an interface logger_iface, defined in includes/tacopie/logger.hpp:
class logger_iface {
// ...
virtual void debug(const std::string& msg, const std::string& file, unsigned int line) = 0;
virtual void info(const std::string& msg, const std::string& file, unsigned int line) = 0;
virtual void warn(const std::string& msg, const std::string& file, unsigned int line) = 0;
virtual void error(const std::string& msg, const std::string& file, unsigned int line) = 0;
// ...
};Your custom logger just has to inherit from that interface and implement the debug, info, warn and error functions.
class my_logger : public tacopie::logger_iface {
// ...
void debug(const std::string& msg, const std::string& file, unsigned int line) { ... }
void info(const std::string& msg, const std::string& file, unsigned int line) { ... }
void warn(const std::string& msg, const std::string& file, unsigned int line) { ... }
void error(const std::string& msg, const std::string& file, unsigned int line) { ... }
// ...
};Then, just set tacopie::active_logger with an instance of your custom logger: your custom logger will automatically be used:
tacopie::active_logger = std::unique_ptr<my_logger>(new my_logger);Need more information? Contact me.