diff --git a/include/fmt/core.h b/include/fmt/core.h index 467fdb86a3a9e..77f36b2aaf236 100644 --- a/include/fmt/core.h +++ b/include/fmt/core.h @@ -257,7 +257,11 @@ #endif #ifndef FMT_UNICODE -# define FMT_UNICODE !FMT_MSC_VERSION +# ifdef _WIN32 +# define FMT_UNICODE 0 +# else +# define FMT_UNICODE 1 +# endif #endif #ifndef FMT_CONSTEVAL diff --git a/include/fmt/ostream.h b/include/fmt/ostream.h index 0fd6c1016a6b1..ef22c1aeafa33 100644 --- a/include/fmt/ostream.h +++ b/include/fmt/ostream.h @@ -95,8 +95,7 @@ inline bool write_ostream_unicode(std::ostream& os, fmt::string_view data) { if (auto* buf = dynamic_cast*>(os.rdbuf())) if (FILE* f = get_file(*buf)) return write_console(f, data); #else - ignore_unused(os); - ignore_unused(data); + ignore_unused(os, data); #endif return false; } @@ -109,7 +108,6 @@ inline bool write_ostream_unicode(std::wostream&, // It is a separate function rather than a part of vprint to simplify testing. template void write_buffer(std::basic_ostream& os, buffer& buf) { - if (write_ostream_unicode(os, {buf.data(), buf.size()})) return; const Char* buf_data = buf.data(); using unsigned_streamsize = std::make_unsigned::type; unsigned_streamsize size = buf.size(); @@ -189,6 +187,17 @@ struct fallback_formatter::value>> using basic_ostream_formatter::format; }; +inline void vprint_directly(std::ostream& os, string_view format_str, + format_args args) { +#ifdef _WIN32 + auto buffer = memory_buffer(); + detail::vformat_to(buffer, format_str, args); + detail::write_buffer(os, buffer); +#else + ignore_unused(os, format_str, args); +#endif +} + } // namespace detail FMT_MODULE_EXPORT template @@ -197,6 +206,7 @@ void vprint(std::basic_ostream& os, basic_format_args>> args) { auto buffer = basic_memory_buffer(); detail::vformat_to(buffer, format_str, args); + if (detail::write_ostream_unicode(os, {buffer.data(), buffer.size()})) return; detail::write_buffer(os, buffer); } @@ -211,7 +221,11 @@ void vprint(std::basic_ostream& os, */ FMT_MODULE_EXPORT template void print(std::ostream& os, format_string fmt, T&&... args) { - vprint(os, fmt, fmt::make_format_args(args...)); + const auto& vargs = fmt::make_format_args(args...); + if (detail::is_utf8()) + vprint(os, fmt, vargs); + else + detail::vprint_directly(os, fmt, vargs); } FMT_MODULE_EXPORT