From 91046e6ca4a0d8c1678d1b25d9c8442db881e6f6 Mon Sep 17 00:00:00 2001 From: Gabi Melman Date: Sat, 13 Feb 2021 20:59:10 +0200 Subject: [PATCH] Simplify wincolor sink color mode management --- include/spdlog/sinks/wincolor_sink-inl.h | 31 +++++++++++++----------- include/spdlog/sinks/wincolor_sink.h | 3 +-- 2 files changed, 18 insertions(+), 16 deletions(-) diff --git a/include/spdlog/sinks/wincolor_sink-inl.h b/include/spdlog/sinks/wincolor_sink-inl.h index 0c0bb1de..04a9e788 100644 --- a/include/spdlog/sinks/wincolor_sink-inl.h +++ b/include/spdlog/sinks/wincolor_sink-inl.h @@ -22,12 +22,7 @@ SPDLOG_INLINE wincolor_sink::wincolor_sink(void *out_handle, color , formatter_(details::make_unique()) { - // check if out_handle is points to the actual console. - // ::GetConsoleMode() should return 0 if it is redirected or not valid console handle. - DWORD console_mode; - in_console_ = ::GetConsoleMode(static_cast(out_handle_), &console_mode) != 0; 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 @@ -65,17 +60,11 @@ void SPDLOG_INLINE wincolor_sink::log(const details::log_msg &msg) msg.color_range_start = 0; msg.color_range_end = 0; memory_buf_t formatted; - formatter_->format(msg, formatted); - if (!in_console_) - { - write_to_file_(formatted); - return; - } + formatter_->format(msg, formatted); if (should_do_colors_ && msg.color_range_end > msg.color_range_start) { // before color range print_range_(formatted, 0, msg.color_range_start); - // in color range auto orig_attribs = static_cast(set_foreground_color_(colors_[msg.level])); print_range_(formatted, msg.color_range_start, msg.color_range_end); @@ -85,7 +74,7 @@ void SPDLOG_INLINE wincolor_sink::log(const details::log_msg &msg) } else // print without colors if color range is invalid (or color is disabled) { - print_range_(formatted, 0, formatted.size()); + write_to_file_(formatted); } } @@ -119,7 +108,21 @@ void SPDLOG_INLINE wincolor_sink::set_color_mode(color_mode mode) template void SPDLOG_INLINE wincolor_sink::set_color_mode_impl(color_mode mode) { - should_do_colors_ = mode != color_mode::never; + switch (mode) + { + case color_mode::always: + should_do_colors_ = true; + break; + case color_mode::never: + should_do_colors_ = false; + break; + default: + // should do colors only if out_handle_ points to actual console. + DWORD console_mode; + bool in_console = ::GetConsoleMode(static_cast(out_handle_), &console_mode) != 0; + should_do_colors_ = in_console; + break; + } } // set foreground color and return the orig console attributes (for resetting later) diff --git a/include/spdlog/sinks/wincolor_sink.h b/include/spdlog/sinks/wincolor_sink.h index d85721f2..a82f1b24 100644 --- a/include/spdlog/sinks/wincolor_sink.h +++ b/include/spdlog/sinks/wincolor_sink.h @@ -41,8 +41,7 @@ public: protected: using mutex_t = typename ConsoleMutex::mutex_t; void *out_handle_; - mutex_t &mutex_; - bool in_console_; + mutex_t &mutex_; bool should_do_colors_; std::unique_ptr formatter_; std::array colors_;