// // Copyright(c) 2015-present Gabi Melman. // Distributed under the MIT License (http://opensource.org/licenses/MIT) #pragma once // lite logger - a pimpl around spdlog::logger shared_ptr: // much faster compile times. // can be used as lib or separate compilation unit. // very cheap copy and move. // supports printf format for even faster compile (by avoiding variadic templates). // // see lite-example/ for usage. #include #include #include "spdlog/fmt/fmt.h" namespace spdlog { class logger; namespace lite { // string_view type - either std::string_view or fmt::string_view (pre c++17) #if defined(FMT_USE_STD_STRING_VIEW) using string_view_t = std::string_view; #else using string_view_t = fmt::string_view; #endif enum class level { trace, debug, info, warn, err, critical, off }; class logger { public: explicit logger(std::shared_ptr impl); logger(const logger &) = default; logger(logger &&) = default; logger &operator=(const logger &) = default; ~logger() = default; bool should_log(lite::level lvl) const noexcept; template void log(lite::level lvl, const char *fmt, const Args &... args) { if (!should_log(lvl)) { return; } fmt::memory_buffer formatted_buf; fmt::format_to(formatted_buf, fmt, args...); log_formatted_(lvl, formatted_buf); } // log string view void log(lite::level lvl, const string_view_t &sv); void log_printf(lite::level lvl, const char *format, va_list args); // // trace // void trace(const char *msg) { log(lite::level::trace, string_view_t(msg)); } template void trace(const char *fmt, const Args &... args) { log(lite::level::trace, fmt, args...); } void trace_printf(const char *format, ...); // // debug // void debug(const char *msg) { log(lite::level::debug, string_view_t(msg)); } template void debug(const char *fmt, const Args &... args) { log(lite::level::debug, fmt, args...); } void debug_printf(const char *format, ...); // // info // void info(const char *msg) { log(lite::level::info, string_view_t(msg)); } template void info(const char *fmt, const Args &... args) { log(lite::level::info, fmt, args...); } void info_printf(const char *format, ...); // // warn // void warn(const char *msg) { log(lite::level::warn, string_view_t(msg)); } template void warn(const char *fmt, const Args &... args) { log(lite::level::warn, fmt, args...); } void warn_printf(const char *format, ...); // // error // void error(const char *msg) { log(lite::level::err, string_view_t(msg)); } template void error(const char *fmt, const Args &... args) { log(lite::level::err, fmt, args...); } void error_printf(const char *format, ...); // // critical // void critical(const char *msg) { log(lite::level::critical, string_view_t(msg)); } template void critical(const char *fmt, const Args &... args) { log(lite::level::critical, fmt, args...); } void critical_printf(const char *format, ...); // // setters/getters // std::string name() const; void set_level(lite::level level); lite::level get_level() const; // // flush // void flush(); void flush_on(lite::level log_level); lite::level flush_level() const; // // set pattern // void set_pattern(std::string pattern); // //clone with new name // spdlog::lite::logger clone(std::string logger_name); protected: std::shared_ptr impl_; void log_formatted_(lite::level lvl, const fmt::memory_buffer &formatted); }; spdlog::lite::logger &default_logger(); template void trace(const char *fmt, const Args &... args) { default_logger().trace(fmt, args...); } template void debug(const char *fmt, const Args &... args) { default_logger().debug(fmt, args...); } template void info(const char *fmt, const Args &... args) { default_logger().info(fmt, args...); } template void warn(const char *fmt, const Args &... args) { default_logger().warn(fmt, args...); } template void error(const char *fmt, const Args &... args) { default_logger().error(fmt, args...); } template void critical(const char *fmt, const Args &... args) { default_logger().critical(fmt, args...); } } // namespace lite // factory to create lite logger // implement it in a dedicated compilation unit for fast compiles spdlog::lite::logger create_lite(void *ctx = nullptr); } // namespace spdlog