From 392917f855edf1a20f175120014003fccdd78543 Mon Sep 17 00:00:00 2001 From: gabime Date: Sat, 23 Sep 2023 00:27:32 +0300 Subject: [PATCH] null_atomic_log_level and fix compile --- README.md | 10 +-- bench/bench.cpp | 6 +- bench/formatter-bench.cpp | 2 +- bench/latency.cpp | 2 +- example/example.cpp | 18 +++--- include/spdlog/cfg/helpers-inl.h | 10 +-- include/spdlog/common-inl.h | 20 ++---- include/spdlog/common.h | 37 ++++++----- include/spdlog/details/log_msg-inl.h | 6 +- include/spdlog/details/log_msg.h | 8 +-- include/spdlog/details/null_mutex.h | 17 +++-- include/spdlog/details/registry-inl.h | 6 +- include/spdlog/details/registry.h | 12 ++-- include/spdlog/logger-inl.h | 14 ++-- include/spdlog/logger.h | 76 +++++++++++----------- include/spdlog/pattern_formatter-inl.h | 8 +-- include/spdlog/sinks/android_sink.h | 14 ++-- include/spdlog/sinks/ansicolor_sink-inl.h | 18 +++--- include/spdlog/sinks/ansicolor_sink.h | 4 +- include/spdlog/sinks/dup_filter_sink.h | 6 +- include/spdlog/sinks/mongo_sink.h | 2 +- include/spdlog/sinks/null_sink.h | 4 +- include/spdlog/sinks/qt_sinks.h | 18 +++--- include/spdlog/sinks/sink-inl.h | 8 +-- include/spdlog/sinks/sink.h | 8 +-- include/spdlog/sinks/syslog_sink.h | 14 ++-- include/spdlog/sinks/systemd_sink.h | 16 ++--- include/spdlog/sinks/win_eventlog_sink.h | 14 ++-- include/spdlog/sinks/wincolor_sink-inl.h | 16 ++--- include/spdlog/sinks/wincolor_sink.h | 4 +- include/spdlog/spdlog-inl.h | 8 +-- include/spdlog/spdlog.h | 76 +++++++++++----------- tests/test_cfg.cpp | 78 +++++++++++------------ tests/test_daily_logger.cpp | 2 +- tests/test_dup_filter.cpp | 20 +++--- tests/test_errors.cpp | 2 +- tests/test_eventlog.cpp | 2 +- tests/test_file_logging.cpp | 4 +- tests/test_macros.cpp | 2 +- tests/test_misc.cpp | 62 +++++++++--------- tests/test_pattern_formatter.cpp | 50 +++++++-------- tests/test_registry.cpp | 4 +- tests/test_stdout_api.cpp | 8 +-- tests/test_systemd.cpp | 2 +- tests/test_time_point.cpp | 12 ++-- 45 files changed, 365 insertions(+), 365 deletions(-) diff --git a/README.md b/README.md index a375e5a5..425773d5 100644 --- a/README.md +++ b/README.md @@ -73,7 +73,7 @@ int main() spdlog::info("Positional args are {1} {0}..", "too", "supported"); spdlog::info("{:<30}", "left aligned"); - spdlog::set_level(spdlog::level::debug); // Set global log level to debug + spdlog::set_level(spdlog::log_level::debug); // Set global log level to debug spdlog::debug("This message should be displayed.."); // change log pattern @@ -220,14 +220,14 @@ void binary_example() void multi_sink_example() { auto console_sink = std::make_shared(); - console_sink->set_level(spdlog::level::warn); + console_sink->set_level(spdlog::log_level::warn); console_sink->set_pattern("[multi_sink_example] [%^%l%$] %v"); auto file_sink = std::make_shared("logs/multisink.txt", true); - file_sink->set_level(spdlog::level::trace); + file_sink->set_level(spdlog::log_level::trace); spdlog::logger logger("multi_sink", {console_sink, file_sink}); - logger.set_level(spdlog::level::debug); + logger.set_level(spdlog::log_level::debug); logger.warn("this should appear in both console and file"); logger.info("this message should not appear in the console, only in the file"); } @@ -244,7 +244,7 @@ void callback_example() auto callback_sink = std::make_shared([](const spdlog::details::log_msg &msg) { // for example you can be notified by sending an email to yourself }); - callback_sink->set_level(spdlog::level::err); + callback_sink->set_level(spdlog::log_level::err); auto console_sink = std::make_shared(); spdlog::logger logger("custom_callback_logger", {console_sink, callback_sink}); diff --git a/bench/bench.cpp b/bench/bench.cpp index 924cbc9f..2896ae7b 100644 --- a/bench/bench.cpp +++ b/bench/bench.cpp @@ -56,7 +56,7 @@ void bench_threaded_logging(size_t threads, int iters) spdlog::info(""); auto empty_logger = std::make_shared("level-off"); - empty_logger->set_level(spdlog::level::off); + empty_logger->set_level(spdlog::log_level::off); bench(iters, empty_logger); } @@ -79,7 +79,7 @@ void bench_single_threaded(int iters) spdlog::info(""); auto empty_logger = std::make_shared("level-off"); - empty_logger->set_level(spdlog::level::off); + empty_logger->set_level(spdlog::log_level::off); bench(iters, empty_logger); } @@ -208,7 +208,7 @@ void bench_c_string(int howmany, std::shared_ptr log) auto start = high_resolution_clock::now(); for (auto i = 0; i < howmany; ++i) { - spdlog::log(spdlog::level::info, msg); + spdlog::log(spdlog::log_level::info, msg); } auto delta = high_resolution_clock::now() - start; diff --git a/bench/formatter-bench.cpp b/bench/formatter-bench.cpp index a7b8bd10..5d60dd18 100644 --- a/bench/formatter-bench.cpp +++ b/bench/formatter-bench.cpp @@ -16,7 +16,7 @@ void bench_formatter(benchmark::State &state, std::string pattern) const char *text = "Hello. This is some message with length of 80 "; spdlog::source_loc source_loc{"a/b/c/d/myfile.cpp", 123, "some_func()"}; - spdlog::details::log_msg msg(source_loc, logger_name, spdlog::level::info, text); + spdlog::details::log_msg msg(source_loc, logger_name, spdlog::log_level::info, text); for (auto _ : state) { diff --git a/bench/latency.cpp b/bench/latency.cpp index 510d2e70..d9c97722 100644 --- a/bench/latency.cpp +++ b/bench/latency.cpp @@ -97,7 +97,7 @@ int main(int argc, char *argv[]) // disabled loggers auto disabled_logger = std::make_shared("bench", std::make_shared()); - disabled_logger->set_level(spdlog::level::off); + disabled_logger->set_level(spdlog::log_level::off); benchmark::RegisterBenchmark("disabled-at-compile-time", bench_disabled_macro, disabled_logger); benchmark::RegisterBenchmark("disabled-at-compile-time (global logger)", bench_disabled_macro_global_logger, disabled_logger); benchmark::RegisterBenchmark("disabled-at-runtime", bench_logger, disabled_logger); diff --git a/example/example.cpp b/example/example.cpp index bf27fa02..0afe3d14 100644 --- a/example/example.cpp +++ b/example/example.cpp @@ -47,16 +47,16 @@ int main(int, char *[]) spdlog::info("{:>8} aligned, {:<8} aligned", "right", "left"); // Runtime log levels - spdlog::set_level(spdlog::level::info); // Set global log level to info + spdlog::set_level(spdlog::log_level::info); // Set global log level to info spdlog::debug("This message should not be displayed!"); - spdlog::set_level(spdlog::level::trace); // Set specific logger's log level + spdlog::set_level(spdlog::log_level::trace); // Set specific logger's log level spdlog::debug("This message should be displayed.."); // Customize msg format for all loggers spdlog::set_pattern("[%H:%M:%S %z] [%^%L%$] [thread %t] %v"); spdlog::info("This an info message with custom format"); spdlog::set_pattern("%+"); // back to default format - spdlog::set_level(spdlog::level::info); + spdlog::set_level(spdlog::log_level::info); try { @@ -243,7 +243,7 @@ void udp_example() { spdlog::sinks::udp_sink_config cfg("127.0.0.1", 11091); auto my_logger = spdlog::udp_logger_mt("udplog", cfg); - my_logger->set_level(spdlog::level::debug); + my_logger->set_level(spdlog::log_level::debug); my_logger->info("hello world"); } @@ -251,14 +251,14 @@ void udp_example() void multi_sink_example() { auto console_sink = std::make_shared(); - console_sink->set_level(spdlog::level::warn); + console_sink->set_level(spdlog::log_level::warn); console_sink->set_pattern("[multi_sink_example] [%^%l%$] %v"); auto file_sink = std::make_shared("logs/multisink.txt", true); - file_sink->set_level(spdlog::level::trace); + file_sink->set_level(spdlog::log_level::trace); spdlog::logger logger("multi_sink", {console_sink, file_sink}); - logger.set_level(spdlog::level::debug); + logger.set_level(spdlog::log_level::debug); logger.warn("this should appear in both console and file"); logger.info("this message should not appear in the console, only in the file"); } @@ -378,9 +378,9 @@ void replace_default_logger_example() auto new_logger = spdlog::basic_logger_mt("new_default_logger", "logs/new-default-log.txt", true); spdlog::set_default_logger(new_logger); - spdlog::set_level(spdlog::level::info); + spdlog::set_level(spdlog::log_level::info); spdlog::debug("This message should not be displayed!"); - spdlog::set_level(spdlog::level::trace); + spdlog::set_level(spdlog::log_level::trace); spdlog::debug("This message should be displayed.."); spdlog::set_default_logger(old_logger); diff --git a/include/spdlog/cfg/helpers-inl.h b/include/spdlog/cfg/helpers-inl.h index 675a13af..f973fad7 100644 --- a/include/spdlog/cfg/helpers-inl.h +++ b/include/spdlog/cfg/helpers-inl.h @@ -87,17 +87,17 @@ SPDLOG_INLINE void load_levels(const std::string &input) } auto key_vals = extract_key_vals_(input); - std::unordered_map levels; - level::level_enum global_level = level::info; + std::unordered_map levels; + log_level global_level = log_level::info; bool global_level_found = false; for (auto &name_level : key_vals) { - auto &logger_name = name_level.first; + const auto &logger_name = name_level.first; auto level_name = to_lower_(name_level.second); - auto level = level::from_str(level_name); + auto level = level_from_str(level_name); // ignore unrecognized level names - if (level == level::off && level_name != "off") + if (level == log_level::off && level_name != "off") { continue; } diff --git a/include/spdlog/common-inl.h b/include/spdlog/common-inl.h index 0bcc0e3b..59c0284c 100644 --- a/include/spdlog/common-inl.h +++ b/include/spdlog/common-inl.h @@ -11,32 +11,24 @@ #include namespace spdlog { -namespace level { -//#if __cplusplus >= 201703L -//constexpr -//#endif -// static string_view_t level_string_views[] SPDLOG_LEVEL_NAMES; - - -SPDLOG_INLINE spdlog::level::level_enum from_str(const std::string &name) noexcept +SPDLOG_INLINE spdlog::log_level level_from_str(const std::string &name) noexcept { - auto it = std::find(std::begin(level_string_views), std::end(level_string_views), name); + const auto *it = std::find(std::begin(level_string_views), std::end(level_string_views), name); if (it != std::end(level_string_views)) - return static_cast(std::distance(std::begin(level_string_views), it)); + return static_cast(std::distance(std::begin(level_string_views), it)); // check also for "warn" and "err" before giving up.. if (name == "warn") { - return level::warn; + return spdlog::log_level::warn; } if (name == "err") { - return level::err; + return log_level::err; } - return level::off; + return log_level::off; } -} // namespace level SPDLOG_INLINE spdlog_ex::spdlog_ex(std::string msg) : msg_(std::move(msg)) diff --git a/include/spdlog/common.h b/include/spdlog/common.h index fe79e779..f17b46e6 100644 --- a/include/spdlog/common.h +++ b/include/spdlog/common.h @@ -142,11 +142,6 @@ using wmemory_buf_t = fmt::basic_memory_buffer; # define SPDLOG_BUF_TO_STRING(x) fmt::to_string(x) #endif // SPDLOG_USE_STD_FORMAT -#if defined(SPDLOG_NO_ATOMIC_LEVELS) -using level_t = details::null_atomic_int; -#else -using level_t = std::atomic; -#endif #define SPDLOG_LEVEL_TRACE 0 #define SPDLOG_LEVEL_DEBUG 1 @@ -165,8 +160,7 @@ template using is_convertible_to_sv = std::enable_if_t>; // Log level enum -namespace level { -enum level_enum : int +enum class log_level { trace = SPDLOG_LEVEL_TRACE, debug = SPDLOG_LEVEL_DEBUG, @@ -178,6 +172,12 @@ enum level_enum : int n_levels }; +#if not defined(SPDLOG_NO_ATOMIC_LEVELS) + using level_t = details::null_atomic_log_level; +#else + using level_t = std::atomic; +#endif + #if !defined(SPDLOG_LEVEL_NAMES) #define SPDLOG_LEVEL_NAMES { "trace", "debug", "info", "warning", "error", "critical", "off"} #endif @@ -186,22 +186,27 @@ enum level_enum : int #define SPDLOG_SHORT_LEVEL_NAMES {"T", "D", "I", "W", "E", "C", "O"} #endif -constexpr std::array level_string_views SPDLOG_LEVEL_NAMES; -constexpr std::arrayshort_level_names SPDLOG_SHORT_LEVEL_NAMES; - -constexpr string_view_t to_string_view(spdlog::level::level_enum lvl) noexcept +constexpr size_t to_size_t(log_level level) noexcept { - return level_string_views.at(lvl); + return static_cast(level); +} +constexpr auto levels_count = to_size_t(log_level::n_levels); +constexpr std::array level_string_views SPDLOG_LEVEL_NAMES; +constexpr std::array short_level_names SPDLOG_SHORT_LEVEL_NAMES; + +constexpr string_view_t to_string_view(spdlog::log_level lvl) noexcept +{ + return level_string_views.at(to_size_t(lvl)); } -constexpr const char *to_short_c_str(spdlog::level::level_enum lvl) noexcept +constexpr const char *to_short_c_str(spdlog::log_level lvl) noexcept { - return short_level_names.at(lvl); + return short_level_names.at(to_size_t(lvl)); } -SPDLOG_API spdlog::level::level_enum from_str(const std::string &name) noexcept; +SPDLOG_API spdlog::log_level level_from_str(const std::string &name) noexcept; + -} // namespace level // // Color mode used by sinks with color support. diff --git a/include/spdlog/details/log_msg-inl.h b/include/spdlog/details/log_msg-inl.h index c6e8a7e0..5c81d8f3 100644 --- a/include/spdlog/details/log_msg-inl.h +++ b/include/spdlog/details/log_msg-inl.h @@ -13,7 +13,7 @@ namespace spdlog { namespace details { SPDLOG_INLINE log_msg::log_msg(spdlog::log_clock::time_point log_time, spdlog::source_loc loc, string_view_t a_logger_name, - spdlog::level::level_enum lvl, spdlog::string_view_t msg) + spdlog::log_level lvl, spdlog::string_view_t msg) : logger_name(a_logger_name) , level(lvl) , time(log_time) @@ -25,11 +25,11 @@ SPDLOG_INLINE log_msg::log_msg(spdlog::log_clock::time_point log_time, spdlog::s {} SPDLOG_INLINE log_msg::log_msg( - spdlog::source_loc loc, string_view_t a_logger_name, spdlog::level::level_enum lvl, spdlog::string_view_t msg) + spdlog::source_loc loc, string_view_t a_logger_name, spdlog::log_level lvl, spdlog::string_view_t msg) : log_msg(os::now(), loc, a_logger_name, lvl, msg) {} -SPDLOG_INLINE log_msg::log_msg(string_view_t a_logger_name, spdlog::level::level_enum lvl, spdlog::string_view_t msg) +SPDLOG_INLINE log_msg::log_msg(string_view_t a_logger_name, spdlog::log_level lvl, spdlog::string_view_t msg) : log_msg(os::now(), source_loc{}, a_logger_name, lvl, msg) {} diff --git a/include/spdlog/details/log_msg.h b/include/spdlog/details/log_msg.h index fed51abd..548810ea 100644 --- a/include/spdlog/details/log_msg.h +++ b/include/spdlog/details/log_msg.h @@ -11,14 +11,14 @@ namespace details { struct SPDLOG_API log_msg { log_msg() = default; - log_msg(log_clock::time_point log_time, source_loc loc, string_view_t logger_name, level::level_enum lvl, string_view_t msg); - log_msg(source_loc loc, string_view_t logger_name, level::level_enum lvl, string_view_t msg); - log_msg(string_view_t logger_name, level::level_enum lvl, string_view_t msg); + log_msg(log_clock::time_point log_time, source_loc loc, string_view_t logger_name, log_level lvl, string_view_t msg); + log_msg(source_loc loc, string_view_t logger_name, log_level lvl, string_view_t msg); + log_msg(string_view_t logger_name, log_level lvl, string_view_t msg); log_msg(const log_msg &other) = default; log_msg &operator=(const log_msg &other) = default; string_view_t logger_name; - level::level_enum level{level::off}; + log_level level{log_level::off}; log_clock::time_point time; size_t thread_id{0}; diff --git a/include/spdlog/details/null_mutex.h b/include/spdlog/details/null_mutex.h index 6550a7bf..eb8af19c 100644 --- a/include/spdlog/details/null_mutex.h +++ b/include/spdlog/details/null_mutex.h @@ -5,9 +5,12 @@ #include #include + // null, no cost dummy "mutex" and dummy "atomic" int namespace spdlog { +enum class log_level; // forward declaration + namespace details { struct null_mutex { @@ -15,26 +18,26 @@ struct null_mutex void unlock() const {} }; -struct null_atomic_int +struct null_atomic_log_level { - int value; - null_atomic_int() = default; + spdlog::log_level value; + null_atomic_log_level() = default; - explicit null_atomic_int(int new_value) + explicit null_atomic_log_level(spdlog::log_level new_value) : value(new_value) {} - int load(std::memory_order = std::memory_order_relaxed) const + [[nodiscard]] log_level load(std::memory_order = std::memory_order_relaxed) const { return value; } - void store(int new_value, std::memory_order = std::memory_order_relaxed) + void store(log_level new_value, std::memory_order = std::memory_order_relaxed) { value = new_value; } - int exchange(int new_value, std::memory_order = std::memory_order_relaxed) + log_level exchange(log_level new_value, std::memory_order = std::memory_order_relaxed) { std::swap(new_value, value); return new_value; // return value before the call diff --git a/include/spdlog/details/registry-inl.h b/include/spdlog/details/registry-inl.h index 3ded8bc0..dc1afee0 100644 --- a/include/spdlog/details/registry-inl.h +++ b/include/spdlog/details/registry-inl.h @@ -142,7 +142,7 @@ SPDLOG_INLINE void registry::set_formatter(std::unique_ptr formatter) } } -SPDLOG_INLINE void registry::set_level(level::level_enum log_level) +SPDLOG_INLINE void registry::set_level(log_level log_level) { std::lock_guard lock(logger_map_mutex_); for (auto &l : loggers_) @@ -152,7 +152,7 @@ SPDLOG_INLINE void registry::set_level(level::level_enum log_level) global_log_level_ = log_level; } -SPDLOG_INLINE void registry::flush_on(level::level_enum log_level) +SPDLOG_INLINE void registry::flush_on(log_level log_level) { std::lock_guard lock(logger_map_mutex_); for (auto &l : loggers_) @@ -235,7 +235,7 @@ SPDLOG_INLINE void registry::set_automatic_registration(bool automatic_registrat automatic_registration_ = automatic_registration; } -SPDLOG_INLINE void registry::set_levels(log_levels levels, level::level_enum *global_level) +SPDLOG_INLINE void registry::set_levels(log_levels levels, log_level *global_level) { std::lock_guard lock(logger_map_mutex_); log_levels_ = std::move(levels); diff --git a/include/spdlog/details/registry.h b/include/spdlog/details/registry.h index 77624491..0c3c47b5 100644 --- a/include/spdlog/details/registry.h +++ b/include/spdlog/details/registry.h @@ -27,7 +27,7 @@ class thread_pool; class SPDLOG_API registry { public: - using log_levels = std::unordered_map; + using log_levels = std::unordered_map; registry(const registry &) = delete; registry &operator=(const registry &) = delete; @@ -53,9 +53,9 @@ public: // Set global formatter. Each sink in each logger will get a clone of this object void set_formatter(std::unique_ptr formatter); - void set_level(level::level_enum log_level); + void set_level(log_level log_level); - void flush_on(level::level_enum log_level); + void flush_on(log_level log_level); template void flush_every(std::chrono::duration interval) @@ -83,7 +83,7 @@ public: void set_automatic_registration(bool automatic_registration); // set levels for all existing/future loggers. global_level can be null if should not set. - void set_levels(log_levels levels, level::level_enum *global_level); + void set_levels(log_levels levels, log_level *global_level); static registry &instance(); @@ -101,8 +101,8 @@ private: std::unordered_map> loggers_; log_levels log_levels_; std::unique_ptr formatter_; - spdlog::level::level_enum global_log_level_ = level::info; - level::level_enum flush_level_ = level::off; + spdlog::log_level global_log_level_ = log_level::info; + log_level flush_level_ = log_level::off; err_handler err_handler_; std::shared_ptr tp_; std::unique_ptr periodic_flusher_; diff --git a/include/spdlog/logger-inl.h b/include/spdlog/logger-inl.h index 05788552..c137b8cc 100644 --- a/include/spdlog/logger-inl.h +++ b/include/spdlog/logger-inl.h @@ -31,14 +31,14 @@ SPDLOG_INLINE logger::logger(logger &&other) noexcept , custom_err_handler_(std::move(other.custom_err_handler_)) {} -SPDLOG_INLINE void logger::set_level(level::level_enum log_level) +SPDLOG_INLINE void logger::set_level(log_level log_level) { level_.store(log_level); } -SPDLOG_INLINE level::level_enum logger::level() const +SPDLOG_INLINE log_level logger::level() const { - return static_cast(level_.load(std::memory_order_relaxed)); + return static_cast(level_.load(std::memory_order_relaxed)); } SPDLOG_INLINE const std::string &logger::name() const @@ -77,14 +77,14 @@ SPDLOG_INLINE void logger::flush() flush_(); } -SPDLOG_INLINE void logger::flush_on(level::level_enum log_level) +SPDLOG_INLINE void logger::flush_on(log_level log_level) { flush_level_.store(log_level); } -SPDLOG_INLINE level::level_enum logger::flush_level() const +SPDLOG_INLINE log_level logger::flush_level() const { - return static_cast(flush_level_.load(std::memory_order_relaxed)); + return static_cast(flush_level_.load(std::memory_order_relaxed)); } // sinks @@ -127,7 +127,7 @@ SPDLOG_INLINE void logger::flush_() SPDLOG_INLINE bool logger::should_flush_(const details::log_msg &msg) { auto flush_level = flush_level_.load(std::memory_order_relaxed); - return (msg.level >= flush_level) && (msg.level != level::off); + return (msg.level >= flush_level) && (msg.level != log_level::off); } SPDLOG_INLINE void logger::err_handler_(const std::string &msg) diff --git a/include/spdlog/logger.h b/include/spdlog/logger.h index 7b485417..59b200b5 100644 --- a/include/spdlog/logger.h +++ b/include/spdlog/logger.h @@ -77,7 +77,7 @@ public: // log functions template - void log(source_loc loc, level::level_enum lvl, format_string_t fmt, Args &&...args) + void log(source_loc loc, log_level lvl, format_string_t fmt, Args &&...args) { if (should_log(lvl)) { @@ -86,7 +86,7 @@ public: } template - void log(level::level_enum lvl, format_string_t fmt, Args &&...args) + void log(log_level lvl, format_string_t fmt, Args &&...args) { if (should_log(lvl)) { @@ -95,7 +95,7 @@ public: } template, typename... Args> - void log(source_loc loc, level::level_enum lvl, S fmt, Args &&...args) + void log(source_loc loc, log_level lvl, S fmt, Args &&...args) { if (should_log(lvl)) { @@ -104,7 +104,7 @@ public: } // log with no format string, just string message - void log(source_loc loc, level::level_enum lvl, string_view_t msg) + void log(source_loc loc, log_level lvl, string_view_t msg) { if (should_log(lvl)) { @@ -112,7 +112,7 @@ public: } } - void log(level::level_enum lvl, string_view_t msg) + void log(log_level lvl, string_view_t msg) { if (should_log(lvl)) { @@ -121,7 +121,7 @@ public: } // support for custom time - void log(log_clock::time_point log_time, source_loc loc, level::level_enum lvl, string_view_t msg) + void log(log_clock::time_point log_time, source_loc loc, log_level lvl, string_view_t msg) { if (should_log(lvl)) { @@ -133,150 +133,150 @@ public: template void trace(loc_with_fmt fmt, Args &&...args) { - log(fmt.loc, level::trace, fmt.fmt_string, std::forward(args)...); + log(fmt.loc, log_level::trace, fmt.fmt_string, std::forward(args)...); } template void debug(loc_with_fmt fmt, Args &&...args) { - log(fmt.loc, level::debug, fmt.fmt_string, std::forward(args)...); + log(fmt.loc, log_level::debug, fmt.fmt_string, std::forward(args)...); } template void info(loc_with_fmt fmt, Args &&...args) { - log(fmt.loc, level::info, fmt.fmt_string, std::forward(args)...); + log(fmt.loc, log_level::info, fmt.fmt_string, std::forward(args)...); } template void warn(loc_with_fmt fmt, Args &&...args) { - log(fmt.loc, level::warn, fmt.fmt_string, std::forward(args)...); + log(fmt.loc, log_level::warn, fmt.fmt_string, std::forward(args)...); } template void error(loc_with_fmt fmt, Args &&...args) { - log(fmt.loc, level::err, fmt.fmt_string, std::forward(args)...); + log(fmt.loc, log_level::err, fmt.fmt_string, std::forward(args)...); } template void critical(loc_with_fmt fmt, Args &&...args) { - log(fmt.loc, level::critical, fmt.fmt_string, std::forward(args)...); + log(fmt.loc, log_level::critical, fmt.fmt_string, std::forward(args)...); } // log functions with no format string, just string void trace(string_view_t msg, source_loc loc = source_loc::current()) { - log(loc, level::trace, msg); + log(loc, log_level::trace, msg); } void debug(string_view_t msg, source_loc loc = source_loc::current()) { - log(loc, level::debug, msg); + log(loc, log_level::debug, msg); } void info(string_view_t msg, source_loc loc = source_loc::current()) { - log(loc, level::info, msg); + log(loc, log_level::info, msg); } void warn(string_view_t msg, source_loc loc = source_loc::current()) { - log(loc, level::warn, msg); + log(loc, log_level::warn, msg); } void error(string_view_t msg, source_loc loc = source_loc::current()) { - log(loc, level::err, msg); + log(loc, log_level::err, msg); } void critical(string_view_t msg, source_loc loc = source_loc::current()) { - log(loc, level::critical, msg); + log(loc, log_level::critical, msg); } #else template void trace(format_string_t fmt, Args &&...args) { - log(level::trace, fmt, std::forward(args)...); + log(log_level::trace, fmt, std::forward(args)...); } template void debug(format_string_t fmt, Args &&...args) { - log(level::debug, fmt, std::forward(args)...); + log(log_level::debug, fmt, std::forward(args)...); } template void info(format_string_t fmt, Args &&...args) { - log(level::info, fmt, std::forward(args)...); + log(log_level::info, fmt, std::forward(args)...); } template void warn(format_string_t fmt, Args &&...args) { - log(level::warn, fmt, std::forward(args)...); + log(log_level::warn, fmt, std::forward(args)...); } template void error(format_string_t fmt, Args &&...args) { - log(level::err, fmt, std::forward(args)...); + log(log_level::err, fmt, std::forward(args)...); } template void critical(format_string_t fmt, Args &&...args) { - log(level::critical, fmt, std::forward(args)...); + log(log_level::critical, fmt, std::forward(args)...); } // log functions with no format string, just string void trace(string_view_t msg) { - log(level::trace, msg); + log(log_level::trace, msg); } void debug(string_view_t msg) { - log(level::debug, msg); + log(log_level::debug, msg); } void info(string_view_t msg) { - log(level::info, msg); + log(log_level::info, msg); } inline void warn(string_view_t msg) { - log(level::warn, msg); + log(log_level::warn, msg); } void error(string_view_t msg) { - log(level::err, msg); + log(log_level::err, msg); } void critical(string_view_t msg) { - log(level::critical, msg); + log(log_level::critical, msg); } #endif // return true if logging is enabled for the given level. - [[nodiscard]] bool should_log(level::level_enum msg_level) const + [[nodiscard]] bool should_log(log_level msg_level) const { return msg_level >= level_.load(std::memory_order_relaxed); } // set the level of logging - void set_level(level::level_enum log_level); + void set_level(log_level log_level); // return the active log level - [[nodiscard]] level::level_enum level() const; + [[nodiscard]] log_level level() const; // return the name of the logger [[nodiscard]] const std::string &name() const; @@ -293,8 +293,8 @@ public: // flush functions void flush(); - void flush_on(level::level_enum log_level); - [[nodiscard]] level::level_enum flush_level() const; + void flush_on(log_level log_level); + [[nodiscard]] log_level flush_level() const; // sinks [[nodiscard]] const std::vector &sinks() const; @@ -310,13 +310,13 @@ public: protected: std::string name_; std::vector sinks_; - spdlog::level_t level_{level::info}; - spdlog::level_t flush_level_{level::off}; + spdlog::level_t level_{log_level::info}; + spdlog::level_t flush_level_{log_level::off}; err_handler custom_err_handler_{nullptr}; // common implementation for after templated public api has been resolved to format string and args template - void log_with_format_(source_loc loc, level::level_enum lvl, string_view_t fmt, Args &&...args) + void log_with_format_(source_loc loc, log_level lvl, string_view_t fmt, Args &&...args) { assert(should_log(lvl)); SPDLOG_TRY diff --git a/include/spdlog/pattern_formatter-inl.h b/include/spdlog/pattern_formatter-inl.h index b28a9e93..a27895a3 100644 --- a/include/spdlog/pattern_formatter-inl.h +++ b/include/spdlog/pattern_formatter-inl.h @@ -129,7 +129,7 @@ public: void format(const details::log_msg &msg, const std::tm &, memory_buf_t &dest) override { - const string_view_t &level_name = level::to_string_view(msg.level); + const string_view_t &level_name = to_string_view(msg.level); ScopedPadder p(level_name.size(), padinfo_, dest); fmt_helper::append_string_view(level_name, dest); } @@ -146,7 +146,7 @@ public: void format(const details::log_msg &msg, const std::tm &, memory_buf_t &dest) override { - string_view_t level_name{level::to_short_c_str(msg.level)}; + string_view_t level_name{to_short_c_str(msg.level)}; ScopedPadder p(level_name.size(), padinfo_, dest); fmt_helper::append_string_view(level_name, dest); } @@ -991,8 +991,8 @@ public: dest.push_back('['); // wrap the level name with color msg.color_range_start = dest.size(); - // fmt_helper::append_string_view(level::to_c_str(msg.level), dest); - fmt_helper::append_string_view(level::to_string_view(msg.level), dest); + // fmt_helper::append_string_view(log_level::to_c_str(msg.level), dest); + fmt_helper::append_string_view(to_string_view(msg.level), dest); msg.color_range_end = dest.size(); dest.push_back(']'); dest.push_back(' '); diff --git a/include/spdlog/sinks/android_sink.h b/include/spdlog/sinks/android_sink.h index 0087e953..793b778b 100644 --- a/include/spdlog/sinks/android_sink.h +++ b/include/spdlog/sinks/android_sink.h @@ -92,21 +92,21 @@ private: return __android_log_buf_write(ID, prio, tag, text); } - static android_LogPriority convert_to_android_(spdlog::level::level_enum level) + static android_LogPriority convert_to_android_(spdlog::log_level level) { switch (level) { - case spdlog::level::trace: + case spdlog::log_level::trace: return ANDROID_LOG_VERBOSE; - case spdlog::level::debug: + case spdlog::log_level::debug: return ANDROID_LOG_DEBUG; - case spdlog::level::info: + case spdlog::log_level::info: return ANDROID_LOG_INFO; - case spdlog::level::warn: + case spdlog::log_level::warn: return ANDROID_LOG_WARN; - case spdlog::level::err: + case spdlog::log_level::err: return ANDROID_LOG_ERROR; - case spdlog::level::critical: + case spdlog::log_level::critical: return ANDROID_LOG_FATAL; default: return ANDROID_LOG_DEFAULT; diff --git a/include/spdlog/sinks/ansicolor_sink-inl.h b/include/spdlog/sinks/ansicolor_sink-inl.h index aea90c27..bbc44d05 100644 --- a/include/spdlog/sinks/ansicolor_sink-inl.h +++ b/include/spdlog/sinks/ansicolor_sink-inl.h @@ -21,17 +21,17 @@ SPDLOG_INLINE ansicolor_sink::ansicolor_sink(FILE *target_file, co { set_color_mode(mode); - colors_.at(level::trace) = to_string_(white); - colors_.at(level::debug) = to_string_(cyan); - colors_.at(level::info) = to_string_(green); - colors_.at(level::warn) = to_string_(yellow_bold); - colors_.at(level::err) = to_string_(red_bold); - colors_.at(level::critical) = to_string_(bold_on_red); - colors_.at(level::off) = to_string_(reset); + colors_.at(to_size_t(log_level::trace)) = to_string_(white); + colors_.at(to_size_t(log_level::debug)) = to_string_(cyan); + colors_.at(to_size_t(log_level::info)) = to_string_(green); + colors_.at(to_size_t(log_level::warn)) = to_string_(yellow_bold); + colors_.at(to_size_t(log_level::err)) = to_string_(red_bold); + colors_.at(to_size_t(log_level::critical)) = to_string_(bold_on_red); + colors_.at(to_size_t(log_level::off)) = to_string_(reset); } template -SPDLOG_INLINE void ansicolor_sink::set_color(level::level_enum color_level, string_view_t color) +SPDLOG_INLINE void ansicolor_sink::set_color(log_level color_level, string_view_t color) { std::lock_guard lock(mutex_); colors_.at(static_cast(color_level)) = to_string_(color); @@ -126,7 +126,7 @@ SPDLOG_INLINE void ansicolor_sink::print_range_(const memory_buf_t template SPDLOG_INLINE std::string ansicolor_sink::to_string_(const string_view_t &sv) { - return std::string(sv.data(), sv.size()); + return {sv.data(), sv.size()}; } // ansicolor_stdout_sink diff --git a/include/spdlog/sinks/ansicolor_sink.h b/include/spdlog/sinks/ansicolor_sink.h index 39d966bc..75d4f38a 100644 --- a/include/spdlog/sinks/ansicolor_sink.h +++ b/include/spdlog/sinks/ansicolor_sink.h @@ -35,7 +35,7 @@ public: ansicolor_sink &operator=(const ansicolor_sink &other) = delete; ansicolor_sink &operator=(ansicolor_sink &&other) = delete; - void set_color(level::level_enum color_level, string_view_t color); + void set_color(log_level color_level, string_view_t color); void set_color_mode(color_mode mode); bool should_color(); @@ -84,7 +84,7 @@ private: mutex_t &mutex_; bool should_do_colors_; std::unique_ptr formatter_; - std::array colors_; + std::array colors_; void print_ccode_(const string_view_t &color_code); void print_range_(const memory_buf_t &formatted, size_t start, size_t end); static std::string to_string_(const string_view_t &sv); diff --git a/include/spdlog/sinks/dup_filter_sink.h b/include/spdlog/sinks/dup_filter_sink.h index 3c96549c..448c25ac 100644 --- a/include/spdlog/sinks/dup_filter_sink.h +++ b/include/spdlog/sinks/dup_filter_sink.h @@ -20,7 +20,7 @@ // #include // // int main() { -// auto dup_filter = std::make_shared(std::chrono::seconds(5), level::info); +// auto dup_filter = std::make_shared(std::chrono::seconds(5), log_level::info); // dup_filter->add_sink(std::make_shared()); // spdlog::logger l("logger", dup_filter); // l.info("Hello"); @@ -41,7 +41,7 @@ class dup_filter_sink : public dist_sink { public: template - explicit dup_filter_sink(std::chrono::duration max_skip_duration, level::level_enum notification_level = level::info) + explicit dup_filter_sink(std::chrono::duration max_skip_duration, log_level notification_level = log_level::info) : max_skip_duration_{max_skip_duration} , log_level_{notification_level} {} @@ -51,7 +51,7 @@ protected: log_clock::time_point last_msg_time_; std::string last_msg_payload_; size_t skip_counter_ = 0; - level::level_enum log_level_; + log_level log_level_; void sink_it_(const details::log_msg &msg) override { diff --git a/include/spdlog/sinks/mongo_sink.h b/include/spdlog/sinks/mongo_sink.h index 91f39b9b..f491b50e 100644 --- a/include/spdlog/sinks/mongo_sink.h +++ b/include/spdlog/sinks/mongo_sink.h @@ -66,7 +66,7 @@ protected: if (client_ != nullptr) { - auto doc = document{} << "timestamp" << bsoncxx::types::b_date(msg.time) << "level" << level::to_string_view(msg.level).data() + auto doc = document{} << "timestamp" << bsoncxx::types::b_date(msg.time) << "level" << log_level::to_string_view(msg.level).data() << "level_num" << msg.level << "message" << std::string(msg.payload.begin(), msg.payload.end()) << "logger_name" << std::string(msg.logger_name.begin(), msg.logger_name.end()) << "thread_id" << static_cast(msg.thread_id) << finalize; diff --git a/include/spdlog/sinks/null_sink.h b/include/spdlog/sinks/null_sink.h index eb832801..e63098f8 100644 --- a/include/spdlog/sinks/null_sink.h +++ b/include/spdlog/sinks/null_sink.h @@ -29,7 +29,7 @@ template inline std::shared_ptr null_logger_mt(const std::string &logger_name) { auto null_logger = Factory::template create(logger_name); - null_logger->set_level(level::off); + null_logger->set_level(log_level::off); return null_logger; } @@ -37,7 +37,7 @@ template inline std::shared_ptr null_logger_st(const std::string &logger_name) { auto null_logger = Factory::template create(logger_name); - null_logger->set_level(level::off); + null_logger->set_level(log_level::off); return null_logger; } diff --git a/include/spdlog/sinks/qt_sinks.h b/include/spdlog/sinks/qt_sinks.h index 92e53af7..9cf93b1e 100644 --- a/include/spdlog/sinks/qt_sinks.h +++ b/include/spdlog/sinks/qt_sinks.h @@ -86,23 +86,23 @@ public: QTextCharFormat format; // trace format.setForeground(dark_colors ? Qt::darkGray : Qt::gray); - colors_.at(level::trace) = format; + colors_.at(log_level::trace) = format; // debug format.setForeground(dark_colors ? Qt::darkCyan : Qt::cyan); - colors_.at(level::debug) = format; + colors_.at(log_level::debug) = format; // info format.setForeground(dark_colors ? Qt::darkGreen : Qt::green); - colors_.at(level::info) = format; + colors_.at(log_level::info) = format; // warn format.setForeground(dark_colors ? Qt::darkYellow : Qt::yellow); - colors_.at(level::warn) = format; + colors_.at(spdlog::log_level::warn) = format; // err format.setForeground(Qt::red); - colors_.at(level::err) = format; + colors_.at(log_level::err) = format; // critical format.setForeground(Qt::white); format.setBackground(Qt::red); - colors_.at(level::critical) = format; + colors_.at(log_level::critical) = format; } ~qt_color_sink() @@ -116,13 +116,13 @@ public: default_color_ = format; } - void set_level_color(level::level_enum color_level, QTextCharFormat format) + void set_level_color(log_level color_level, QTextCharFormat format) { // std::lock_guard lock(base_sink::mutex_); colors_.at(static_cast(color_level)) = format; } - QTextCharFormat &get_level_color(level::level_enum color_level) + QTextCharFormat &get_level_color(log_level color_level) { std::lock_guard lock(base_sink::mutex_); return colors_.at(static_cast(color_level)); @@ -238,7 +238,7 @@ protected: int max_lines_; bool is_utf8_; QTextCharFormat default_color_; - std::array colors_; + std::array colors_; }; #include "spdlog/details/null_mutex.h" diff --git a/include/spdlog/sinks/sink-inl.h b/include/spdlog/sinks/sink-inl.h index df07adda..16664c58 100644 --- a/include/spdlog/sinks/sink-inl.h +++ b/include/spdlog/sinks/sink-inl.h @@ -9,17 +9,17 @@ #include -SPDLOG_INLINE bool spdlog::sinks::sink::should_log(spdlog::level::level_enum msg_level) const +SPDLOG_INLINE bool spdlog::sinks::sink::should_log(spdlog::log_level msg_level) const { return msg_level >= level_.load(std::memory_order_relaxed); } -SPDLOG_INLINE void spdlog::sinks::sink::set_level(level::level_enum log_level) +SPDLOG_INLINE void spdlog::sinks::sink::set_level(log_level log_level) { level_.store(log_level, std::memory_order_relaxed); } -SPDLOG_INLINE spdlog::level::level_enum spdlog::sinks::sink::level() const +SPDLOG_INLINE spdlog::log_level spdlog::sinks::sink::level() const { - return static_cast(level_.load(std::memory_order_relaxed)); + return static_cast(level_.load(std::memory_order_relaxed)); } diff --git a/include/spdlog/sinks/sink.h b/include/spdlog/sinks/sink.h index 0a28cccc..68cd8524 100644 --- a/include/spdlog/sinks/sink.h +++ b/include/spdlog/sinks/sink.h @@ -18,13 +18,13 @@ public: virtual void set_pattern(const std::string &pattern) = 0; virtual void set_formatter(std::unique_ptr sink_formatter) = 0; - void set_level(level::level_enum log_level); - level::level_enum level() const; - bool should_log(level::level_enum msg_level) const; + void set_level(log_level log_level); + log_level level() const; + bool should_log(log_level msg_level) const; protected: // sink log level - default is all - level_t level_{level::trace}; + level_t level_{log_level::trace}; }; } // namespace sinks diff --git a/include/spdlog/sinks/syslog_sink.h b/include/spdlog/sinks/syslog_sink.h index 7c38fcb5..3bf04d76 100644 --- a/include/spdlog/sinks/syslog_sink.h +++ b/include/spdlog/sinks/syslog_sink.h @@ -23,13 +23,13 @@ class syslog_sink : public base_sink public: syslog_sink(std::string ident, int syslog_option, int syslog_facility, bool enable_formatting) : enable_formatting_{enable_formatting} - , syslog_levels_{{/* spdlog::level::trace */ LOG_DEBUG, - /* spdlog::level::debug */ LOG_DEBUG, - /* spdlog::level::info */ LOG_INFO, - /* spdlog::level::warn */ LOG_WARNING, - /* spdlog::level::err */ LOG_ERR, - /* spdlog::level::critical */ LOG_CRIT, - /* spdlog::level::off */ LOG_INFO}} + , syslog_levels_{{/* spdlog::log_level::trace */ LOG_DEBUG, + /* spdlog::log_level::debug */ LOG_DEBUG, + /* spdlog::log_level::info */ LOG_INFO, + /* spdlog::log_level::warn */ LOG_WARNING, + /* spdlog::log_level::err */ LOG_ERR, + /* spdlog::log_level::critical */ LOG_CRIT, + /* spdlog::log_level::off */ LOG_INFO}} , ident_{std::move(ident)} { // set ident to be program name if empty diff --git a/include/spdlog/sinks/systemd_sink.h b/include/spdlog/sinks/systemd_sink.h index b00a95f2..1b5cc5a9 100644 --- a/include/spdlog/sinks/systemd_sink.h +++ b/include/spdlog/sinks/systemd_sink.h @@ -27,13 +27,13 @@ public: systemd_sink(std::string ident = "", bool enable_formatting = false) : ident_{std::move(ident)} , enable_formatting_{enable_formatting} - , syslog_levels_{{/* spdlog::level::trace */ LOG_DEBUG, - /* spdlog::level::debug */ LOG_DEBUG, - /* spdlog::level::info */ LOG_INFO, - /* spdlog::level::warn */ LOG_WARNING, - /* spdlog::level::err */ LOG_ERR, - /* spdlog::level::critical */ LOG_CRIT, - /* spdlog::level::off */ LOG_INFO}} + , syslog_levels_{{/* spdlog::log_level::trace */ LOG_DEBUG, + /* spdlog::log_level::debug */ LOG_DEBUG, + /* spdlog::log_level::info */ LOG_INFO, + /* spdlog::log_level::warn */ LOG_WARNING, + /* spdlog::log_level::err */ LOG_ERR, + /* spdlog::log_level::critical */ LOG_CRIT, + /* spdlog::log_level::off */ LOG_INFO}} {} ~systemd_sink() override {} @@ -97,7 +97,7 @@ protected: } } - int syslog_level(level::level_enum l) + int syslog_level(log_level l) { return syslog_levels_.at(static_cast(l)); } diff --git a/include/spdlog/sinks/win_eventlog_sink.h b/include/spdlog/sinks/win_eventlog_sink.h index fb12e290..f3d16263 100644 --- a/include/spdlog/sinks/win_eventlog_sink.h +++ b/include/spdlog/sinks/win_eventlog_sink.h @@ -174,19 +174,19 @@ struct eventlog { switch (msg.level) { - case level::trace: - case level::debug: + case log_level::trace: + case log_level::debug: return EVENTLOG_SUCCESS; - case level::info: + case log_level::info: return EVENTLOG_INFORMATION_TYPE; - case level::warn: + case spdlog::log_level::warn: return EVENTLOG_WARNING_TYPE; - case level::err: - case level::critical: - case level::off: + case log_level::err: + case log_level::critical: + case log_level::off: return EVENTLOG_ERROR_TYPE; default: diff --git a/include/spdlog/sinks/wincolor_sink-inl.h b/include/spdlog/sinks/wincolor_sink-inl.h index ee713590..495ea46e 100644 --- a/include/spdlog/sinks/wincolor_sink-inl.h +++ b/include/spdlog/sinks/wincolor_sink-inl.h @@ -24,14 +24,14 @@ SPDLOG_INLINE wincolor_sink::wincolor_sink(void *out_handle, color set_color_mode_impl(mode); // set level colors - colors_[level::trace] = FOREGROUND_RED | FOREGROUND_GREEN | FOREGROUND_BLUE; // white - colors_[level::debug] = FOREGROUND_GREEN | FOREGROUND_BLUE; // cyan - colors_[level::info] = FOREGROUND_GREEN; // green - colors_[level::warn] = FOREGROUND_RED | FOREGROUND_GREEN | FOREGROUND_INTENSITY; // intense yellow - colors_[level::err] = FOREGROUND_RED | FOREGROUND_INTENSITY; // intense red - colors_[level::critical] = + colors_[log_level::trace] = FOREGROUND_RED | FOREGROUND_GREEN | FOREGROUND_BLUE; // white + colors_[log_level::debug] = FOREGROUND_GREEN | FOREGROUND_BLUE; // cyan + colors_[log_level::info] = FOREGROUND_GREEN; // green + colors_[spdlog::log_level::warn] = FOREGROUND_RED | FOREGROUND_GREEN | FOREGROUND_INTENSITY; // intense yellow + colors_[log_level::err] = FOREGROUND_RED | FOREGROUND_INTENSITY; // intense red + colors_[log_level::critical] = BACKGROUND_RED | FOREGROUND_RED | FOREGROUND_GREEN | FOREGROUND_BLUE | FOREGROUND_INTENSITY; // intense white on red background - colors_[level::off] = 0; + colors_[log_level::off] = 0; } template @@ -42,7 +42,7 @@ SPDLOG_INLINE wincolor_sink::~wincolor_sink() // change the color for the given level template -void SPDLOG_INLINE wincolor_sink::set_color(level::level_enum level, std::uint16_t color) +void SPDLOG_INLINE wincolor_sink::set_color(log_level level, std::uint16_t color) { std::lock_guard lock(mutex_); colors_[static_cast(level)] = color; diff --git a/include/spdlog/sinks/wincolor_sink.h b/include/spdlog/sinks/wincolor_sink.h index 9b030fc1..1ab9a5ed 100644 --- a/include/spdlog/sinks/wincolor_sink.h +++ b/include/spdlog/sinks/wincolor_sink.h @@ -31,7 +31,7 @@ public: wincolor_sink &operator=(const wincolor_sink &other) = delete; // change the color for the given level - void set_color(level::level_enum level, std::uint16_t color); + void set_color(log_level level, std::uint16_t color); void log(const details::log_msg &msg) final override; void flush() final override; void set_pattern(const std::string &pattern) override final; @@ -44,7 +44,7 @@ protected: mutex_t &mutex_; bool should_do_colors_; std::unique_ptr formatter_; - std::array colors_; + std::array colors_; // set foreground color and return the orig console attributes (for resetting later) std::uint16_t set_foreground_color_(std::uint16_t attribs); diff --git a/include/spdlog/spdlog-inl.h b/include/spdlog/spdlog-inl.h index c52ff3bc..c2e4530d 100644 --- a/include/spdlog/spdlog-inl.h +++ b/include/spdlog/spdlog-inl.h @@ -32,22 +32,22 @@ SPDLOG_INLINE void set_pattern(std::string pattern, pattern_time_type time_type) set_formatter(std::unique_ptr(new pattern_formatter(std::move(pattern), time_type))); } -SPDLOG_INLINE level::level_enum get_level() +SPDLOG_INLINE log_level get_level() { return default_logger_raw()->level(); } -SPDLOG_INLINE bool should_log(level::level_enum log_level) +SPDLOG_INLINE bool should_log(log_level log_level) { return default_logger_raw()->should_log(log_level); } -SPDLOG_INLINE void set_level(level::level_enum log_level) +SPDLOG_INLINE void set_level(log_level log_level) { details::registry::instance().set_level(log_level); } -SPDLOG_INLINE void flush_on(level::level_enum log_level) +SPDLOG_INLINE void flush_on(log_level log_level) { details::registry::instance().flush_on(log_level); } diff --git a/include/spdlog/spdlog.h b/include/spdlog/spdlog.h index 5e65a95e..5d905bd6 100644 --- a/include/spdlog/spdlog.h +++ b/include/spdlog/spdlog.h @@ -59,16 +59,16 @@ SPDLOG_API void set_formatter(std::unique_ptr formatter); SPDLOG_API void set_pattern(std::string pattern, pattern_time_type time_type = pattern_time_type::local); // Get global logging level -SPDLOG_API level::level_enum get_level(); +SPDLOG_API log_level get_level(); // Set global logging level -SPDLOG_API void set_level(level::level_enum log_level); +SPDLOG_API void set_level(log_level log_level); // Determine whether the default logger should log messages with a certain level -SPDLOG_API bool should_log(level::level_enum lvl); +SPDLOG_API bool should_log(log_level lvl); // Set global flush level -SPDLOG_API void flush_on(level::level_enum log_level); +SPDLOG_API void flush_on(log_level log_level); // Start/Restart a periodic flusher thread // Warning: Use only if all your loggers are thread safe! @@ -132,25 +132,25 @@ SPDLOG_API void set_default_logger(std::shared_ptr default_logge SPDLOG_API void apply_logger_env_levels(std::shared_ptr logger); template -inline void log(source_loc source, level::level_enum lvl, format_string_t fmt, Args &&...args) +inline void log(source_loc source, log_level lvl, format_string_t fmt, Args &&...args) { default_logger_raw()->log(source, lvl, fmt, std::forward(args)...); } template -inline void log(level::level_enum lvl, format_string_t fmt, Args &&...args) +inline void log(log_level lvl, format_string_t fmt, Args &&...args) { default_logger_raw()->log(lvl, fmt, std::forward(args)...); } template, typename... Args> -inline void log(source_loc loc, level::level_enum lvl, S fmt, Args &&...args) +inline void log(source_loc loc, log_level lvl, S fmt, Args &&...args) { default_logger_raw()->log(loc, lvl, fmt, std::forward(args)...); } template, typename... Args> -inline void log(level::level_enum lvl, S fmt, Args &&...args) +inline void log(log_level lvl, S fmt, Args &&...args) { default_logger_raw()->log(lvl, fmt, std::forward(args)...); } @@ -159,135 +159,135 @@ inline void log(level::level_enum lvl, S fmt, Args &&...args) template inline void trace(loc_with_fmt fmt, Args &&...args) { - log(fmt.loc, level::trace, fmt.fmt_string, std::forward(args)...); + log(fmt.loc, log_level::trace, fmt.fmt_string, std::forward(args)...); } template inline void debug(loc_with_fmt fmt, Args &&...args) { - log(fmt.loc, level::debug, fmt.fmt_string, std::forward(args)...); + log(fmt.loc, log_level::debug, fmt.fmt_string, std::forward(args)...); } template inline void info(loc_with_fmt fmt, Args &&...args) { - log(fmt.loc, level::info, fmt.fmt_string, std::forward(args)...); + log(fmt.loc, log_level::info, fmt.fmt_string, std::forward(args)...); } template inline void warn(loc_with_fmt fmt, Args &&...args) { - log(fmt.loc, level::warn, fmt.fmt_string, std::forward(args)...); + log(fmt.loc, spdlog::log_level::warn, fmt.fmt_string, std::forward(args)...); } template inline void error(loc_with_fmt fmt, Args &&...args) { - log(fmt.loc, level::err, fmt.fmt_string, std::forward(args)...); + log(fmt.loc, log_level::err, fmt.fmt_string, std::forward(args)...); } template inline void critical(loc_with_fmt fmt, Args &&...args) { - log(fmt.loc, level::critical, fmt.fmt_string, std::forward(args)...); + log(fmt.loc, log_level::critical, fmt.fmt_string, std::forward(args)...); } // log functions with no format string, just string inline void trace(string_view_t msg, source_loc loc = source_loc::current()) { - log(loc, level::trace, msg); + log(loc, log_level::trace, msg); } inline void debug(string_view_t msg, source_loc loc = source_loc::current()) { - log(loc, level::debug, msg); + log(loc, log_level::debug, msg); } inline void info(string_view_t msg, source_loc loc = source_loc::current()) { - log(loc, level::info, msg); + log(loc, log_level::info, msg); } inline void warn(string_view_t msg, source_loc loc = source_loc::current()) { - log(loc, level::warn, msg); + log(loc, spdlog::log_level::warn, msg); } inline void error(string_view_t msg, source_loc loc = source_loc::current()) { - log(loc, level::err, msg); + log(loc, log_level::err, msg); } inline void critical(string_view_t msg, source_loc loc = source_loc::current()) { - log(loc, level::critical, msg); + log(loc, log_level::critical, msg); } #else template inline void trace(format_string_t fmt, Args &&...args) { - log(level::trace, fmt, std::forward(args)...); + log(log_level::trace, fmt, std::forward(args)...); } template inline void debug(format_string_t fmt, Args &&...args) { - log(level::debug, fmt, std::forward(args)...); + log(log_level::debug, fmt, std::forward(args)...); } template inline void info(format_string_t fmt, Args &&...args) { - log(level::info, fmt, std::forward(args)...); + log(log_level::info, fmt, std::forward(args)...); } template inline void warn(format_string_t fmt, Args &&...args) { - log(level::warn, fmt, std::forward(args)...); + log(log_level::warn, fmt, std::forward(args)...); } template inline void error(format_string_t fmt, Args &&...args) { - log(level::err, fmt, std::forward(args)...); + log(log_level::err, fmt, std::forward(args)...); } template inline void critical(format_string_t fmt, Args &&...args) { - log(level::critical, fmt, std::forward(args)...); + log(log_level::critical, fmt, std::forward(args)...); } // log functions with no format string, just string inline void trace(string_view_t msg) { - log(level::trace, msg); + log(log_level::trace, msg); } inline void debug(string_view_t msg) { - log(level::debug, msg); + log(log_level::debug, msg); } inline void info(string_view_t msg) { - log(level::info, msg); + log(log_level::info, msg); } inline void warn(string_view_t msg) { - log(level::warn, msg); + log(log_level::warn, msg); } inline void error(string_view_t msg) { - log(level::err, msg); + log(log_level::err, msg); } inline void critical(string_view_t msg) { - log(level::critical, msg); + log(log_level::critical, msg); } #endif @@ -314,7 +314,7 @@ inline void critical(string_view_t msg) #endif #if SPDLOG_ACTIVE_LEVEL <= SPDLOG_LEVEL_TRACE -# define SPDLOG_LOGGER_TRACE(logger, ...) SPDLOG_LOGGER_CALL(logger, spdlog::level::trace, __VA_ARGS__) +# define SPDLOG_LOGGER_TRACE(logger, ...) SPDLOG_LOGGER_CALL(logger, spdlog::log_level::trace, __VA_ARGS__) # define SPDLOG_TRACE(...) SPDLOG_LOGGER_TRACE(spdlog::default_logger_raw(), __VA_ARGS__) #else # define SPDLOG_LOGGER_TRACE(logger, ...) (void)0 @@ -322,7 +322,7 @@ inline void critical(string_view_t msg) #endif #if SPDLOG_ACTIVE_LEVEL <= SPDLOG_LEVEL_DEBUG -# define SPDLOG_LOGGER_DEBUG(logger, ...) SPDLOG_LOGGER_CALL(logger, spdlog::level::debug, __VA_ARGS__) +# define SPDLOG_LOGGER_DEBUG(logger, ...) SPDLOG_LOGGER_CALL(logger, spdlog::log_level::debug, __VA_ARGS__) # define SPDLOG_DEBUG(...) SPDLOG_LOGGER_DEBUG(spdlog::default_logger_raw(), __VA_ARGS__) #else # define SPDLOG_LOGGER_DEBUG(logger, ...) (void)0 @@ -330,7 +330,7 @@ inline void critical(string_view_t msg) #endif #if SPDLOG_ACTIVE_LEVEL <= SPDLOG_LEVEL_INFO -# define SPDLOG_LOGGER_INFO(logger, ...) SPDLOG_LOGGER_CALL(logger, spdlog::level::info, __VA_ARGS__) +# define SPDLOG_LOGGER_INFO(logger, ...) SPDLOG_LOGGER_CALL(logger, spdlog::log_level::info, __VA_ARGS__) # define SPDLOG_INFO(...) SPDLOG_LOGGER_INFO(spdlog::default_logger_raw(), __VA_ARGS__) #else # define SPDLOG_LOGGER_INFO(logger, ...) (void)0 @@ -338,7 +338,7 @@ inline void critical(string_view_t msg) #endif #if SPDLOG_ACTIVE_LEVEL <= SPDLOG_LEVEL_WARN -# define SPDLOG_LOGGER_WARN(logger, ...) SPDLOG_LOGGER_CALL(logger, spdlog::level::warn, __VA_ARGS__) +# define SPDLOG_LOGGER_WARN(logger, ...) SPDLOG_LOGGER_CALL(logger, spdlog::log_level::warn, __VA_ARGS__) # define SPDLOG_WARN(...) SPDLOG_LOGGER_WARN(spdlog::default_logger_raw(), __VA_ARGS__) #else # define SPDLOG_LOGGER_WARN(logger, ...) (void)0 @@ -346,7 +346,7 @@ inline void critical(string_view_t msg) #endif #if SPDLOG_ACTIVE_LEVEL <= SPDLOG_LEVEL_ERROR -# define SPDLOG_LOGGER_ERROR(logger, ...) SPDLOG_LOGGER_CALL(logger, spdlog::level::err, __VA_ARGS__) +# define SPDLOG_LOGGER_ERROR(logger, ...) SPDLOG_LOGGER_CALL(logger, spdlog::log_level::err, __VA_ARGS__) # define SPDLOG_ERROR(...) SPDLOG_LOGGER_ERROR(spdlog::default_logger_raw(), __VA_ARGS__) #else # define SPDLOG_LOGGER_ERROR(logger, ...) (void)0 @@ -354,7 +354,7 @@ inline void critical(string_view_t msg) #endif #if SPDLOG_ACTIVE_LEVEL <= SPDLOG_LEVEL_CRITICAL -# define SPDLOG_LOGGER_CRITICAL(logger, ...) SPDLOG_LOGGER_CALL(logger, spdlog::level::critical, __VA_ARGS__) +# define SPDLOG_LOGGER_CRITICAL(logger, ...) SPDLOG_LOGGER_CALL(logger, spdlog::log_level::critical, __VA_ARGS__) # define SPDLOG_CRITICAL(...) SPDLOG_LOGGER_CRITICAL(spdlog::default_logger_raw(), __VA_ARGS__) #else # define SPDLOG_LOGGER_CRITICAL(logger, ...) (void)0 diff --git a/tests/test_cfg.cpp b/tests/test_cfg.cpp index 11aefa20..f58d500c 100644 --- a/tests/test_cfg.cpp +++ b/tests/test_cfg.cpp @@ -19,9 +19,9 @@ TEST_CASE("env", "[cfg]") setenv("SPDLOG_LEVEL", "l1=warn", 1); #endif load_env_levels(); - REQUIRE(l1->level() == spdlog::level::warn); + REQUIRE(l1->level() == spdlog::log_level::warn); spdlog::set_default_logger(spdlog::create("cfg-default")); - REQUIRE(spdlog::default_logger()->level() == spdlog::level::info); + REQUIRE(spdlog::default_logger()->level() == spdlog::log_level::info); } TEST_CASE("argv1", "[cfg]") @@ -30,8 +30,8 @@ TEST_CASE("argv1", "[cfg]") const char *argv[] = {"ignore", "SPDLOG_LEVEL=l1=warn"}; load_argv_levels(2, argv); auto l1 = spdlog::create("l1"); - REQUIRE(l1->level() == spdlog::level::warn); - REQUIRE(spdlog::default_logger()->level() == spdlog::level::info); + REQUIRE(l1->level() == spdlog::log_level::warn); + REQUIRE(spdlog::default_logger()->level() == spdlog::log_level::info); } TEST_CASE("argv2", "[cfg]") @@ -40,60 +40,60 @@ TEST_CASE("argv2", "[cfg]") const char *argv[] = {"ignore", "SPDLOG_LEVEL=l1=warn,trace"}; load_argv_levels(2, argv); auto l1 = spdlog::create("l1"); - REQUIRE(l1->level() == spdlog::level::warn); - REQUIRE(spdlog::default_logger()->level() == spdlog::level::trace); + REQUIRE(l1->level() == spdlog::log_level::warn); + REQUIRE(spdlog::default_logger()->level() == spdlog::log_level::trace); } TEST_CASE("argv3", "[cfg]") { - spdlog::set_level(spdlog::level::trace); + spdlog::set_level(spdlog::log_level::trace); spdlog::drop("l1"); const char *argv[] = {"ignore", "SPDLOG_LEVEL=junk_name=warn"}; load_argv_levels(2, argv); auto l1 = spdlog::create("l1"); - REQUIRE(l1->level() == spdlog::level::trace); - REQUIRE(spdlog::default_logger()->level() == spdlog::level::trace); + REQUIRE(l1->level() == spdlog::log_level::trace); + REQUIRE(spdlog::default_logger()->level() == spdlog::log_level::trace); } TEST_CASE("argv4", "[cfg]") { - spdlog::set_level(spdlog::level::info); + spdlog::set_level(spdlog::log_level::info); spdlog::drop("l1"); const char *argv[] = {"ignore", "SPDLOG_LEVEL=junk"}; load_argv_levels(2, argv); auto l1 = spdlog::create("l1"); - REQUIRE(l1->level() == spdlog::level::info); + REQUIRE(l1->level() == spdlog::log_level::info); } TEST_CASE("argv5", "[cfg]") { - spdlog::set_level(spdlog::level::info); + spdlog::set_level(spdlog::log_level::info); spdlog::drop("l1"); const char *argv[] = {"ignore", "ignore", "SPDLOG_LEVEL=l1=warn,trace"}; load_argv_levels(3, argv); auto l1 = spdlog::create("l1"); - REQUIRE(l1->level() == spdlog::level::warn); - REQUIRE(spdlog::default_logger()->level() == spdlog::level::trace); - spdlog::set_level(spdlog::level::info); + REQUIRE(l1->level() == spdlog::log_level::warn); + REQUIRE(spdlog::default_logger()->level() == spdlog::log_level::trace); + spdlog::set_level(spdlog::log_level::info); } TEST_CASE("argv6", "[cfg]") { - spdlog::set_level(spdlog::level::err); + spdlog::set_level(spdlog::log_level::err); const char *argv[] = {""}; load_argv_levels(1, argv); - REQUIRE(spdlog::default_logger()->level() == spdlog::level::err); - spdlog::set_level(spdlog::level::info); + REQUIRE(spdlog::default_logger()->level() == spdlog::log_level::err); + spdlog::set_level(spdlog::log_level::info); } TEST_CASE("argv7", "[cfg]") { - spdlog::set_level(spdlog::level::err); + spdlog::set_level(spdlog::log_level::err); const char *argv[] = {""}; load_argv_levels(0, argv); - REQUIRE(spdlog::default_logger()->level() == spdlog::level::err); - spdlog::set_level(spdlog::level::info); + REQUIRE(spdlog::default_logger()->level() == spdlog::log_level::err); + spdlog::set_level(spdlog::log_level::info); } TEST_CASE("level-not-set-test1", "[cfg]") @@ -102,9 +102,9 @@ TEST_CASE("level-not-set-test1", "[cfg]") const char *argv[] = {"ignore", ""}; load_argv_levels(2, argv); auto l1 = spdlog::create("l1"); - l1->set_level(spdlog::level::trace); - REQUIRE(l1->level() == spdlog::level::trace); - REQUIRE(spdlog::default_logger()->level() == spdlog::level::info); + l1->set_level(spdlog::log_level::trace); + REQUIRE(l1->level() == spdlog::log_level::trace); + REQUIRE(spdlog::default_logger()->level() == spdlog::log_level::info); } TEST_CASE("level-not-set-test2", "[cfg]") @@ -114,15 +114,15 @@ TEST_CASE("level-not-set-test2", "[cfg]") const char *argv[] = {"ignore", "SPDLOG_LEVEL=l1=trace"}; auto l1 = spdlog::create("l1"); - l1->set_level(spdlog::level::warn); + l1->set_level(spdlog::log_level::warn); auto l2 = spdlog::create("l2"); - l2->set_level(spdlog::level::warn); + l2->set_level(spdlog::log_level::warn); load_argv_levels(2, argv); - REQUIRE(l1->level() == spdlog::level::trace); - REQUIRE(l2->level() == spdlog::level::warn); - REQUIRE(spdlog::default_logger()->level() == spdlog::level::info); + REQUIRE(l1->level() == spdlog::log_level::trace); + REQUIRE(l2->level() == spdlog::log_level::warn); + REQUIRE(spdlog::default_logger()->level() == spdlog::log_level::info); } TEST_CASE("level-not-set-test3", "[cfg]") @@ -136,9 +136,9 @@ TEST_CASE("level-not-set-test3", "[cfg]") auto l1 = spdlog::create("l1"); auto l2 = spdlog::create("l2"); - REQUIRE(l1->level() == spdlog::level::trace); - REQUIRE(l2->level() == spdlog::level::info); - REQUIRE(spdlog::default_logger()->level() == spdlog::level::info); + REQUIRE(l1->level() == spdlog::log_level::trace); + REQUIRE(l2->level() == spdlog::log_level::info); + REQUIRE(spdlog::default_logger()->level() == spdlog::log_level::info); } TEST_CASE("level-not-set-test4", "[cfg]") @@ -152,9 +152,9 @@ TEST_CASE("level-not-set-test4", "[cfg]") auto l1 = spdlog::create("l1"); auto l2 = spdlog::create("l2"); - REQUIRE(l1->level() == spdlog::level::trace); - REQUIRE(l2->level() == spdlog::level::warn); - REQUIRE(spdlog::default_logger()->level() == spdlog::level::warn); + REQUIRE(l1->level() == spdlog::log_level::trace); + REQUIRE(l2->level() == spdlog::log_level::warn); + REQUIRE(spdlog::default_logger()->level() == spdlog::log_level::warn); } TEST_CASE("level-not-set-test5", "[cfg]") @@ -168,9 +168,9 @@ TEST_CASE("level-not-set-test5", "[cfg]") auto l1 = spdlog::create("l1"); auto l2 = spdlog::create("l2"); - REQUIRE(l1->level() == spdlog::level::warn); - REQUIRE(l2->level() == spdlog::level::warn); - REQUIRE(spdlog::default_logger()->level() == spdlog::level::warn); + REQUIRE(l1->level() == spdlog::log_level::warn); + REQUIRE(l2->level() == spdlog::log_level::warn); + REQUIRE(spdlog::default_logger()->level() == spdlog::log_level::warn); } TEST_CASE("restore-to-default", "[cfg]") @@ -179,5 +179,5 @@ TEST_CASE("restore-to-default", "[cfg]") spdlog::drop("l2"); const char *argv[] = {"ignore", "SPDLOG_LEVEL=info"}; load_argv_levels(2, argv); - REQUIRE(spdlog::default_logger()->level() == spdlog::level::info); + REQUIRE(spdlog::default_logger()->level() == spdlog::log_level::info); } diff --git a/tests/test_daily_logger.cpp b/tests/test_daily_logger.cpp index 82f28941..78602fed 100644 --- a/tests/test_daily_logger.cpp +++ b/tests/test_daily_logger.cpp @@ -137,7 +137,7 @@ TEST_CASE("daily_file_sink::daily_filename_format_calculator", "[daily_file_sink static spdlog::details::log_msg create_msg(std::chrono::seconds offset) { using spdlog::log_clock; - spdlog::details::log_msg msg{"test", spdlog::level::info, "Hello Message"}; + spdlog::details::log_msg msg{"test", spdlog::log_level::info, "Hello Message"}; msg.time = log_clock::now() + offset; return msg; } diff --git a/tests/test_dup_filter.cpp b/tests/test_dup_filter.cpp index 8ae2ee60..9b5b3921 100644 --- a/tests/test_dup_filter.cpp +++ b/tests/test_dup_filter.cpp @@ -13,7 +13,7 @@ TEST_CASE("dup_filter_test1", "[dup_filter_sink]") for (int i = 0; i < 10; i++) { - dup_sink.log(spdlog::details::log_msg{"test", spdlog::level::info, "message1"}); + dup_sink.log(spdlog::details::log_msg{"test", spdlog::log_level::info, "message1"}); } REQUIRE(test_sink->msg_counter() == 1); @@ -30,7 +30,7 @@ TEST_CASE("dup_filter_test2", "[dup_filter_sink]") for (int i = 0; i < 10; i++) { - dup_sink.log(spdlog::details::log_msg{"test", spdlog::level::info, "message1"}); + dup_sink.log(spdlog::details::log_msg{"test", spdlog::log_level::info, "message1"}); std::this_thread::sleep_for(std::chrono::milliseconds(5)); } @@ -48,8 +48,8 @@ TEST_CASE("dup_filter_test3", "[dup_filter_sink]") for (int i = 0; i < 10; i++) { - dup_sink.log(spdlog::details::log_msg{"test", spdlog::level::info, "message1"}); - dup_sink.log(spdlog::details::log_msg{"test", spdlog::level::info, "message2"}); + dup_sink.log(spdlog::details::log_msg{"test", spdlog::log_level::info, "message1"}); + dup_sink.log(spdlog::details::log_msg{"test", spdlog::log_level::info, "message2"}); } REQUIRE(test_sink->msg_counter() == 20); @@ -64,9 +64,9 @@ TEST_CASE("dup_filter_test4", "[dup_filter_sink]") auto test_sink = std::make_shared(); dup_sink.add_sink(test_sink); - dup_sink.log(spdlog::details::log_msg{"test", spdlog::level::info, "message"}); + dup_sink.log(spdlog::details::log_msg{"test", spdlog::log_level::info, "message"}); std::this_thread::sleep_for(std::chrono::milliseconds(50)); - dup_sink.log(spdlog::details::log_msg{"test", spdlog::level::info, "message"}); + dup_sink.log(spdlog::details::log_msg{"test", spdlog::log_level::info, "message"}); REQUIRE(test_sink->msg_counter() == 2); } @@ -80,10 +80,10 @@ TEST_CASE("dup_filter_test5", "[dup_filter_sink]") test_sink->set_pattern("%v"); dup_sink.add_sink(test_sink); - dup_sink.log(spdlog::details::log_msg{"test", spdlog::level::info, "message1"}); - dup_sink.log(spdlog::details::log_msg{"test", spdlog::level::info, "message1"}); - dup_sink.log(spdlog::details::log_msg{"test", spdlog::level::info, "message1"}); - dup_sink.log(spdlog::details::log_msg{"test", spdlog::level::info, "message2"}); + dup_sink.log(spdlog::details::log_msg{"test", spdlog::log_level::info, "message1"}); + dup_sink.log(spdlog::details::log_msg{"test", spdlog::log_level::info, "message1"}); + dup_sink.log(spdlog::details::log_msg{"test", spdlog::log_level::info, "message1"}); + dup_sink.log(spdlog::details::log_msg{"test", spdlog::log_level::info, "message2"}); REQUIRE(test_sink->msg_counter() == 3); // skip 2 messages but log the "skipped.." message before message2 REQUIRE(test_sink->lines()[1] == "Skipped 2 duplicate messages.."); diff --git a/tests/test_errors.cpp b/tests/test_errors.cpp index 0f6ee348..ae764f40 100644 --- a/tests/test_errors.cpp +++ b/tests/test_errors.cpp @@ -45,7 +45,7 @@ TEST_CASE("custom_error_handler", "[errors]") prepare_logdir(); spdlog::filename_t filename = SPDLOG_FILENAME_T(SIMPLE_LOG); auto logger = spdlog::create("logger", filename, true); - logger->flush_on(spdlog::level::info); + logger->flush_on(spdlog::log_level::info); logger->set_error_handler([=](const std::string &) { throw custom_ex(); }); logger->info("Good message #1"); diff --git a/tests/test_eventlog.cpp b/tests/test_eventlog.cpp index 5253c5a7..1d54d839 100644 --- a/tests/test_eventlog.cpp +++ b/tests/test_eventlog.cpp @@ -56,7 +56,7 @@ TEST_CASE("eventlog", "[eventlog]") auto test_sink = std::make_shared(TEST_SOURCE); spdlog::logger test_logger("eventlog", test_sink); - test_logger.set_level(level::trace); + test_logger.set_level(log_level::trace); test_sink->set_pattern("%v"); diff --git a/tests/test_file_logging.cpp b/tests/test_file_logging.cpp index 7a7119ad..4844b0a2 100644 --- a/tests/test_file_logging.cpp +++ b/tests/test_file_logging.cpp @@ -30,8 +30,8 @@ TEST_CASE("flush_on", "[flush_on]") auto logger = spdlog::create("logger", filename); logger->set_pattern("%v"); - logger->set_level(spdlog::level::trace); - logger->flush_on(spdlog::level::info); + logger->set_level(spdlog::log_level::trace); + logger->flush_on(spdlog::log_level::info); logger->trace("Should not be flushed"); REQUIRE(count_lines(SIMPLE_LOG) == 0); diff --git a/tests/test_macros.cpp b/tests/test_macros.cpp index 36537958..b82e40cd 100644 --- a/tests/test_macros.cpp +++ b/tests/test_macros.cpp @@ -18,7 +18,7 @@ TEST_CASE("debug and trace w/o format string", "[macros]") auto logger = spdlog::create("logger", filename); logger->set_pattern("%v"); - logger->set_level(spdlog::level::trace); + logger->set_level(spdlog::log_level::trace); SPDLOG_LOGGER_TRACE(logger, "Test message 1"); SPDLOG_LOGGER_DEBUG(logger, "Test message 2"); diff --git a/tests/test_misc.cpp b/tests/test_misc.cpp index 57defb01..fcf9de6a 100644 --- a/tests/test_misc.cpp +++ b/tests/test_misc.cpp @@ -2,7 +2,7 @@ #include "test_sink.h" template -std::string log_info(const T &what, spdlog::level::level_enum logger_level = spdlog::level::info) +std::string log_info(const T &what, spdlog::log_level logger_level = spdlog::log_level::info) { std::ostringstream oss; @@ -29,46 +29,46 @@ TEST_CASE("basic_logging ", "[basic_logging]") TEST_CASE("log_levels", "[log_levels]") { - REQUIRE(log_info("Hello", spdlog::level::err).empty()); - REQUIRE(log_info("Hello", spdlog::level::critical).empty()); - REQUIRE(log_info("Hello", spdlog::level::info) == "Hello"); - REQUIRE(log_info("Hello", spdlog::level::debug) == "Hello"); - REQUIRE(log_info("Hello", spdlog::level::trace) == "Hello"); + REQUIRE(log_info("Hello", spdlog::log_level::err).empty()); + REQUIRE(log_info("Hello", spdlog::log_level::critical).empty()); + REQUIRE(log_info("Hello", spdlog::log_level::info) == "Hello"); + REQUIRE(log_info("Hello", spdlog::log_level::debug) == "Hello"); + REQUIRE(log_info("Hello", spdlog::log_level::trace) == "Hello"); } TEST_CASE("level_to_string_view", "[convert_to_string_view]") { - REQUIRE(spdlog::level::to_string_view(spdlog::level::trace) == "trace"); - REQUIRE(spdlog::level::to_string_view(spdlog::level::debug) == "debug"); - REQUIRE(spdlog::level::to_string_view(spdlog::level::info) == "info"); - REQUIRE(spdlog::level::to_string_view(spdlog::level::warn) == "warning"); - REQUIRE(spdlog::level::to_string_view(spdlog::level::err) == "error"); - REQUIRE(spdlog::level::to_string_view(spdlog::level::critical) == "critical"); - REQUIRE(spdlog::level::to_string_view(spdlog::level::off) == "off"); + REQUIRE(spdlog::to_string_view(spdlog::log_level::trace) == "trace"); + REQUIRE(spdlog::to_string_view(spdlog::log_level::debug) == "debug"); + REQUIRE(spdlog::to_string_view(spdlog::log_level::info) == "info"); + REQUIRE(spdlog::to_string_view(spdlog::log_level::warn) == "warning"); + REQUIRE(spdlog::to_string_view(spdlog::log_level::err) == "error"); + REQUIRE(spdlog::to_string_view(spdlog::log_level::critical) == "critical"); + REQUIRE(spdlog::to_string_view(spdlog::log_level::off) == "off"); } TEST_CASE("to_short_c_str", "[convert_to_short_c_str]") { - REQUIRE(std::string(spdlog::level::to_short_c_str(spdlog::level::trace)) == "T"); - REQUIRE(std::string(spdlog::level::to_short_c_str(spdlog::level::debug)) == "D"); - REQUIRE(std::string(spdlog::level::to_short_c_str(spdlog::level::info)) == "I"); - REQUIRE(std::string(spdlog::level::to_short_c_str(spdlog::level::warn)) == "W"); - REQUIRE(std::string(spdlog::level::to_short_c_str(spdlog::level::err)) == "E"); - REQUIRE(std::string(spdlog::level::to_short_c_str(spdlog::level::critical)) == "C"); - REQUIRE(std::string(spdlog::level::to_short_c_str(spdlog::level::off)) == "O"); + REQUIRE(std::string(spdlog::to_short_c_str(spdlog::log_level::trace)) == "T"); + REQUIRE(std::string(spdlog::to_short_c_str(spdlog::log_level::debug)) == "D"); + REQUIRE(std::string(spdlog::to_short_c_str(spdlog::log_level::info)) == "I"); + REQUIRE(std::string(spdlog::to_short_c_str(spdlog::log_level::warn)) == "W"); + REQUIRE(std::string(spdlog::to_short_c_str(spdlog::log_level::err)) == "E"); + REQUIRE(std::string(spdlog::to_short_c_str(spdlog::log_level::critical)) == "C"); + REQUIRE(std::string(spdlog::to_short_c_str(spdlog::log_level::off)) == "O"); } TEST_CASE("to_level_enum", "[convert_to_level_enum]") { - REQUIRE(spdlog::level::from_str("trace") == spdlog::level::trace); - REQUIRE(spdlog::level::from_str("debug") == spdlog::level::debug); - REQUIRE(spdlog::level::from_str("info") == spdlog::level::info); - REQUIRE(spdlog::level::from_str("warning") == spdlog::level::warn); - REQUIRE(spdlog::level::from_str("warn") == spdlog::level::warn); - REQUIRE(spdlog::level::from_str("error") == spdlog::level::err); - REQUIRE(spdlog::level::from_str("critical") == spdlog::level::critical); - REQUIRE(spdlog::level::from_str("off") == spdlog::level::off); - REQUIRE(spdlog::level::from_str("null") == spdlog::level::off); + REQUIRE(spdlog::level_from_str("trace") == spdlog::log_level::trace); + REQUIRE(spdlog::level_from_str("debug") == spdlog::log_level::debug); + REQUIRE(spdlog::level_from_str("info") == spdlog::log_level::info); + REQUIRE(spdlog::level_from_str("warning") == spdlog::log_level::warn); + REQUIRE(spdlog::level_from_str("warn") == spdlog::log_level::warn); + REQUIRE(spdlog::level_from_str("error") == spdlog::log_level::err); + REQUIRE(spdlog::level_from_str("critical") == spdlog::log_level::critical); + REQUIRE(spdlog::level_from_str("off") == spdlog::log_level::off); + REQUIRE(spdlog::level_from_str("null") == spdlog::log_level::off); } TEST_CASE("periodic flush", "[periodic_flush]") @@ -140,7 +140,7 @@ TEST_CASE("default logger API", "[default logger]") spdlog::set_default_logger(std::make_shared("oss", oss_sink)); spdlog::set_pattern("*** %v"); - spdlog::default_logger()->set_level(spdlog::level::trace); + spdlog::default_logger()->set_level(spdlog::log_level::trace); spdlog::trace("hello trace"); REQUIRE(oss.str() == "*** hello trace" + std::string(spdlog::details::os::default_eol)); @@ -161,7 +161,7 @@ TEST_CASE("default logger API", "[default logger]") REQUIRE(oss.str() == "*** some string" + std::string(spdlog::details::os::default_eol)); oss.str(""); - spdlog::set_level(spdlog::level::info); + spdlog::set_level(spdlog::log_level::info); spdlog::debug("should not be logged"); REQUIRE(oss.str().empty()); spdlog::drop_all(); diff --git a/tests/test_pattern_formatter.cpp b/tests/test_pattern_formatter.cpp index e6edfca1..9f202e7d 100644 --- a/tests/test_pattern_formatter.cpp +++ b/tests/test_pattern_formatter.cpp @@ -11,7 +11,7 @@ static std::string log_to_str(const std::string &msg, const Args &...args) std::ostringstream oss; auto oss_sink = std::make_shared(oss); spdlog::logger oss_logger("pattern_tester", oss_sink); - oss_logger.set_level(spdlog::level::info); + oss_logger.set_level(spdlog::log_level::info); oss_logger.set_formatter(std::unique_ptr(new spdlog::pattern_formatter(args...))); @@ -68,7 +68,7 @@ TEST_CASE("color range test1", "[pattern_formatter]") spdlog::fmt_lib::format_to(std::back_inserter(buf), "Hello"); memory_buf_t formatted; std::string logger_name = "test"; - spdlog::details::log_msg msg(logger_name, spdlog::level::info, spdlog::string_view_t(buf.data(), buf.size())); + spdlog::details::log_msg msg(logger_name, spdlog::log_level::info, spdlog::string_view_t(buf.data(), buf.size())); formatter->format(msg, formatted); REQUIRE(msg.color_range_start == 0); REQUIRE(msg.color_range_end == 5); @@ -79,7 +79,7 @@ TEST_CASE("color range test2", "[pattern_formatter]") { auto formatter = std::make_shared("%^%$", spdlog::pattern_time_type::local, "\n"); std::string logger_name = "test"; - spdlog::details::log_msg msg(logger_name, spdlog::level::info, ""); + spdlog::details::log_msg msg(logger_name, spdlog::log_level::info, ""); memory_buf_t formatted; formatter->format(msg, formatted); REQUIRE(msg.color_range_start == 0); @@ -91,7 +91,7 @@ TEST_CASE("color range test3", "[pattern_formatter]") { auto formatter = std::make_shared("%^***%$"); std::string logger_name = "test"; - spdlog::details::log_msg msg(logger_name, spdlog::level::info, "ignored"); + spdlog::details::log_msg msg(logger_name, spdlog::log_level::info, "ignored"); memory_buf_t formatted; formatter->format(msg, formatted); REQUIRE(msg.color_range_start == 0); @@ -102,7 +102,7 @@ TEST_CASE("color range test4", "[pattern_formatter]") { auto formatter = std::make_shared("XX%^YYY%$", spdlog::pattern_time_type::local, "\n"); std::string logger_name = "test"; - spdlog::details::log_msg msg(logger_name, spdlog::level::info, "ignored"); + spdlog::details::log_msg msg(logger_name, spdlog::log_level::info, "ignored"); memory_buf_t formatted; formatter->format(msg, formatted); @@ -115,7 +115,7 @@ TEST_CASE("color range test5", "[pattern_formatter]") { auto formatter = std::make_shared("**%^"); std::string logger_name = "test"; - spdlog::details::log_msg msg(logger_name, spdlog::level::info, "ignored"); + spdlog::details::log_msg msg(logger_name, spdlog::log_level::info, "ignored"); memory_buf_t formatted; formatter->format(msg, formatted); REQUIRE(msg.color_range_start == 2); @@ -126,7 +126,7 @@ TEST_CASE("color range test6", "[pattern_formatter]") { auto formatter = std::make_shared("**%$"); std::string logger_name = "test"; - spdlog::details::log_msg msg(logger_name, spdlog::level::info, "ignored"); + spdlog::details::log_msg msg(logger_name, spdlog::log_level::info, "ignored"); memory_buf_t formatted; formatter->format(msg, formatted); REQUIRE(msg.color_range_start == 0); @@ -236,11 +236,11 @@ TEST_CASE("padding_truncate_funcname", "[pattern_formatter]") auto formatter = std::unique_ptr(new spdlog::pattern_formatter(pattern)); test_sink.set_formatter(std::move(formatter)); - spdlog::details::log_msg msg1{spdlog::source_loc{"ignored", 1, "func"}, "test_logger", spdlog::level::info, "message"}; + spdlog::details::log_msg msg1{spdlog::source_loc{"ignored", 1, "func"}, "test_logger", spdlog::log_level::info, "message"}; test_sink.log(msg1); REQUIRE(test_sink.lines()[0] == "message [ func]"); - spdlog::details::log_msg msg2{spdlog::source_loc{"ignored", 1, "function"}, "test_logger", spdlog::level::info, "message"}; + spdlog::details::log_msg msg2{spdlog::source_loc{"ignored", 1, "function"}, "test_logger", spdlog::log_level::info, "message"}; test_sink.log(msg2); REQUIRE(test_sink.lines()[1] == "message [funct]"); } @@ -253,11 +253,11 @@ TEST_CASE("padding_funcname", "[pattern_formatter]") auto formatter = std::unique_ptr(new spdlog::pattern_formatter(pattern)); test_sink.set_formatter(std::move(formatter)); - spdlog::details::log_msg msg1{spdlog::source_loc{"ignored", 1, "func"}, "test_logger", spdlog::level::info, "message"}; + spdlog::details::log_msg msg1{spdlog::source_loc{"ignored", 1, "func"}, "test_logger", spdlog::log_level::info, "message"}; test_sink.log(msg1); REQUIRE(test_sink.lines()[0] == "message [ func]"); - spdlog::details::log_msg msg2{spdlog::source_loc{"ignored", 1, "func567890123"}, "test_logger", spdlog::level::info, "message"}; + spdlog::details::log_msg msg2{spdlog::source_loc{"ignored", 1, "func567890123"}, "test_logger", spdlog::log_level::info, "message"}; test_sink.log(msg2); REQUIRE(test_sink.lines()[1] == "message [func567890123]"); } @@ -267,7 +267,7 @@ TEST_CASE("clone-default-formatter", "[pattern_formatter]") auto formatter_1 = std::make_shared(); auto formatter_2 = formatter_1->clone(); std::string logger_name = "test"; - spdlog::details::log_msg msg(logger_name, spdlog::level::info, "some message"); + spdlog::details::log_msg msg(logger_name, spdlog::log_level::info, "some message"); memory_buf_t formatted_1; memory_buf_t formatted_2; @@ -282,7 +282,7 @@ TEST_CASE("clone-default-formatter2", "[pattern_formatter]") auto formatter_1 = std::make_shared("%+"); auto formatter_2 = formatter_1->clone(); std::string logger_name = "test"; - spdlog::details::log_msg msg(logger_name, spdlog::level::info, "some message"); + spdlog::details::log_msg msg(logger_name, spdlog::log_level::info, "some message"); memory_buf_t formatted_1; memory_buf_t formatted_2; @@ -297,7 +297,7 @@ TEST_CASE("clone-formatter", "[pattern_formatter]") auto formatter_1 = std::make_shared("%D %X [%] [%n] %v"); auto formatter_2 = formatter_1->clone(); std::string logger_name = "test"; - spdlog::details::log_msg msg(logger_name, spdlog::level::info, "some message"); + spdlog::details::log_msg msg(logger_name, spdlog::log_level::info, "some message"); memory_buf_t formatted_1; memory_buf_t formatted_2; @@ -313,7 +313,7 @@ TEST_CASE("clone-formatter-2", "[pattern_formatter]") auto formatter_1 = std::make_shared("%D %X [%] [%n] %v", pattern_time_type::utc, "xxxxxx\n"); auto formatter_2 = formatter_1->clone(); std::string logger_name = "test2"; - spdlog::details::log_msg msg(logger_name, spdlog::level::info, "some message"); + spdlog::details::log_msg msg(logger_name, spdlog::log_level::info, "some message"); memory_buf_t formatted_1; memory_buf_t formatted_2; @@ -364,7 +364,7 @@ TEST_CASE("clone-custom_formatter", "[pattern_formatter]") formatter_1->add_flag('t', "custom_output").set_pattern("[%n] [%t] %v"); auto formatter_2 = formatter_1->clone(); std::string logger_name = "logger-name"; - spdlog::details::log_msg msg(logger_name, spdlog::level::info, "some message"); + spdlog::details::log_msg msg(logger_name, spdlog::log_level::info, "some message"); memory_buf_t formatted_1; memory_buf_t formatted_2; @@ -393,7 +393,7 @@ TEST_CASE("short filename formatter-1", "[pattern_formatter]") memory_buf_t formatted; std::string logger_name = "logger-name"; spdlog::source_loc source_loc{test_path, 123, "some_func()"}; - spdlog::details::log_msg msg(source_loc, "logger-name", spdlog::level::info, "Hello"); + spdlog::details::log_msg msg(source_loc, "logger-name", spdlog::log_level::info, "Hello"); formatter.format(msg, formatted); REQUIRE(to_string_view(formatted) == "myfile.cpp"); @@ -405,7 +405,7 @@ TEST_CASE("short filename formatter-2", "[pattern_formatter]") memory_buf_t formatted; std::string logger_name = "logger-name"; spdlog::source_loc source_loc{"myfile.cpp", 123, "some_func()"}; - spdlog::details::log_msg msg(source_loc, "logger-name", spdlog::level::info, "Hello"); + spdlog::details::log_msg msg(source_loc, "logger-name", spdlog::log_level::info, "Hello"); formatter.format(msg, formatted); REQUIRE(to_string_view(formatted) == "myfile.cpp:123"); @@ -417,7 +417,7 @@ TEST_CASE("short filename formatter-3", "[pattern_formatter]") memory_buf_t formatted; std::string logger_name = "logger-name"; spdlog::source_loc source_loc{"", 123, "some_func()"}; - spdlog::details::log_msg msg(source_loc, "logger-name", spdlog::level::info, "Hello"); + spdlog::details::log_msg msg(source_loc, "logger-name", spdlog::log_level::info, "Hello"); formatter.format(msg, formatted); REQUIRE(to_string_view(formatted) == " Hello"); @@ -429,7 +429,7 @@ TEST_CASE("full filename formatter", "[pattern_formatter]") memory_buf_t formatted; std::string logger_name = "logger-name"; spdlog::source_loc source_loc{test_path, 123, "some_func()"}; - spdlog::details::log_msg msg(source_loc, "logger-name", spdlog::level::info, "Hello"); + spdlog::details::log_msg msg(source_loc, "logger-name", spdlog::log_level::info, "Hello"); formatter.format(msg, formatted); REQUIRE(to_string_view(formatted) == test_path); @@ -442,7 +442,7 @@ TEST_CASE("custom flags", "[pattern_formatter]") memory_buf_t formatted; - spdlog::details::log_msg msg(spdlog::source_loc{}, "logger-name", spdlog::level::info, "some message"); + spdlog::details::log_msg msg(spdlog::source_loc{}, "logger-name", spdlog::log_level::info, "some message"); formatter->format(msg, formatted); auto expected = spdlog::fmt_lib::format("[logger-name] [custom1] [custom2] some message{}", spdlog::details::os::default_eol); @@ -456,7 +456,7 @@ TEST_CASE("custom flags-padding", "[pattern_formatter]") memory_buf_t formatted; - spdlog::details::log_msg msg(spdlog::source_loc{}, "logger-name", spdlog::level::info, "some message"); + spdlog::details::log_msg msg(spdlog::source_loc{}, "logger-name", spdlog::log_level::info, "some message"); formatter->format(msg, formatted); auto expected = spdlog::fmt_lib::format("[logger-name] [custom1] [ custom2] some message{}", spdlog::details::os::default_eol); @@ -469,7 +469,7 @@ TEST_CASE("custom flags-exception", "[pattern_formatter]") formatter->add_flag('t', "throw_me").add_flag('u', "custom2").set_pattern("[%n] [%t] [%u] %v"); memory_buf_t formatted; - spdlog::details::log_msg msg(spdlog::source_loc{}, "logger-name", spdlog::level::info, "some message"); + spdlog::details::log_msg msg(spdlog::source_loc{}, "logger-name", spdlog::log_level::info, "some message"); CHECK_THROWS_AS(formatter->format(msg, formatted), spdlog::spdlog_ex); } @@ -480,7 +480,7 @@ TEST_CASE("override need_localtime", "[pattern_formatter]") { memory_buf_t formatted; - spdlog::details::log_msg msg(spdlog::source_loc{}, "logger-name", spdlog::level::info, "some message"); + spdlog::details::log_msg msg(spdlog::source_loc{}, "logger-name", spdlog::log_level::info, "some message"); formatter->format(msg, formatted); REQUIRE(to_string_view(formatted) == "0:00AM> some message\n"); } @@ -494,7 +494,7 @@ TEST_CASE("override need_localtime", "[pattern_formatter]") << "> some message\n"; memory_buf_t formatted; - spdlog::details::log_msg msg(spdlog::source_loc{}, "logger-name", spdlog::level::info, "some message"); + spdlog::details::log_msg msg(spdlog::source_loc{}, "logger-name", spdlog::log_level::info, "some message"); formatter->format(msg, formatted); REQUIRE(to_string_view(formatted) == oss.str()); } diff --git a/tests/test_registry.cpp b/tests/test_registry.cpp index 8e632cc6..89baa077 100644 --- a/tests/test_registry.cpp +++ b/tests/test_registry.cpp @@ -99,7 +99,7 @@ TEST_CASE("set_default_logger(nullptr)", "[registry]") TEST_CASE("disable automatic registration", "[registry]") { // set some global parameters - spdlog::level::level_enum log_level = spdlog::level::level_enum::warn; + spdlog::log_level log_level = spdlog::log_level::warn; spdlog::set_level(log_level); // but disable automatic registration spdlog::set_automatic_registration(false); @@ -111,6 +111,6 @@ TEST_CASE("disable automatic registration", "[registry]") // but make sure they are still initialized according to global defaults REQUIRE(logger1->level() == log_level); REQUIRE(logger2->level() == log_level); - spdlog::set_level(spdlog::level::info); + spdlog::set_level(spdlog::log_level::info); spdlog::set_automatic_registration(true); } diff --git a/tests/test_stdout_api.cpp b/tests/test_stdout_api.cpp index a6bd5874..c07c5471 100644 --- a/tests/test_stdout_api.cpp +++ b/tests/test_stdout_api.cpp @@ -8,7 +8,7 @@ TEST_CASE("stdout_st", "[stdout]") { auto l = spdlog::stdout_logger_st("test"); l->set_pattern("%+"); - l->set_level(spdlog::level::trace); + l->set_level(spdlog::log_level::trace); l->trace("Test stdout_st"); spdlog::drop_all(); } @@ -17,7 +17,7 @@ TEST_CASE("stdout_mt", "[stdout]") { auto l = spdlog::stdout_logger_mt("test"); l->set_pattern("%+"); - l->set_level(spdlog::level::debug); + l->set_level(spdlog::log_level::debug); l->debug("Test stdout_mt"); spdlog::drop_all(); } @@ -54,7 +54,7 @@ TEST_CASE("stdout_color_mt", "[stdout]") { auto l = spdlog::stdout_color_mt("test"); l->set_pattern("%+"); - l->set_level(spdlog::level::trace); + l->set_level(spdlog::log_level::trace); l->trace("Test stdout_color_mt"); spdlog::drop_all(); } @@ -63,7 +63,7 @@ TEST_CASE("stderr_color_st", "[stderr]") { auto l = spdlog::stderr_color_st("test"); l->set_pattern("%+"); - l->set_level(spdlog::level::debug); + l->set_level(spdlog::log_level::debug); l->debug("Test stderr_color_st"); spdlog::drop_all(); } diff --git a/tests/test_systemd.cpp b/tests/test_systemd.cpp index 8688f41d..141d364a 100644 --- a/tests/test_systemd.cpp +++ b/tests/test_systemd.cpp @@ -5,7 +5,7 @@ TEST_CASE("systemd", "[all]") { auto systemd_sink = std::make_shared(); spdlog::logger logger("spdlog_systemd_test", systemd_sink); - logger.set_level(spdlog::level::trace); + logger.set_level(spdlog::log_level::trace); logger.trace("test spdlog trace"); logger.debug("test spdlog debug"); SPDLOG_LOGGER_INFO((&logger), "test spdlog info"); diff --git a/tests/test_time_point.cpp b/tests/test_time_point.cpp index bacff69a..b38b1825 100644 --- a/tests/test_time_point.cpp +++ b/tests/test_time_point.cpp @@ -15,15 +15,15 @@ TEST_CASE("time_point1", "[time_point log_msg]") test_sink->set_delay(std::chrono::milliseconds(10)); for (int i = 0; i < 5; i++) { - spdlog::details::log_msg msg{tp, source, "test_logger", spdlog::level::info, "message"}; + spdlog::details::log_msg msg{tp, source, "test_logger", spdlog::log_level::info, "message"}; test_sink->log(msg); } - logger.log(tp, source, spdlog::level::info, "formatted message"); - logger.log(tp, source, spdlog::level::info, "formatted message"); - logger.log(tp, source, spdlog::level::info, "formatted message"); - logger.log(tp, source, spdlog::level::info, "formatted message"); - logger.log(source, spdlog::level::info, "formatted message"); // last line has different time_point + logger.log(tp, source, spdlog::log_level::info, "formatted message"); + logger.log(tp, source, spdlog::log_level::info, "formatted message"); + logger.log(tp, source, spdlog::log_level::info, "formatted message"); + logger.log(tp, source, spdlog::log_level::info, "formatted message"); + logger.log(source, spdlog::log_level::info, "formatted message"); // last line has different time_point // now the real test... that the times are the same. std::vector lines = test_sink->lines();