diff --git a/include/spdlog/logger.h b/include/spdlog/logger.h index 05a40a52..7abfb0d8 100644 --- a/include/spdlog/logger.h +++ b/include/spdlog/logger.h @@ -364,7 +364,12 @@ protected: SPDLOG_TRY { memory_buf_t buf; +#ifdef SPDLOG_USE_STD_FORMAT fmt_lib::vformat_to(std::back_inserter(buf), fmt, fmt_lib::make_format_args(std::forward(args)...)); +#else + //seems that fmt::detail::vformat_to(buf, ...) is ~20ns faster than fmt::vformat_to(std::back_inserter(buf),..) + fmt::detail::vformat_to(buf, fmt, fmt::make_format_args(std::forward(args)...)); +#endif details::log_msg log_msg(loc, name_, lvl, string_view_t(buf.data(), buf.size())); log_it_(log_msg, log_enabled, traceback_enabled); @@ -386,7 +391,11 @@ protected: { // format to wmemory_buffer and convert to utf8 wmemory_buf_t wbuf; +#ifdef SPDLOG_USE_STD_FORMAT fmt_lib::vformat_to(std::back_inserter(wbuf), fmt, fmt_lib::make_format_args(std::forward(args)...)); +#else + fmt::detail::vformat_to(wbuf, fmt, fmt::make_format_args(std::forward(args)...)); +#endif memory_buf_t buf; details::os::wstr_to_utf8buf(wstring_view_t(wbuf.data(), wbuf.size()), buf);