diff --git a/include/fmt/core.h b/include/fmt/core.h index 7e6de98f79b0..e9dc7e7b74ac 100644 --- a/include/fmt/core.h +++ b/include/fmt/core.h @@ -1076,6 +1076,8 @@ class locale_ref { locale_ref() : locale_(nullptr) {} template explicit locale_ref(const Locale& loc); + explicit operator bool() const FMT_NOEXCEPT { return locale_ != nullptr; } + template Locale get() const; }; diff --git a/include/fmt/ostream.h b/include/fmt/ostream.h index 18ae820c6877..72d078b20c61 100644 --- a/include/fmt/ostream.h +++ b/include/fmt/ostream.h @@ -89,9 +89,11 @@ void write(std::basic_ostream& os, buffer& buf) { } template -void format_value(buffer& buf, const T& value) { +void format_value(buffer& buf, const T& value, + locale_ref loc = locale_ref()) { formatbuf format_buf(buf); std::basic_ostream output(&format_buf); + if (loc) output.imbue(loc.get()); output.exceptions(std::ios_base::failbit | std::ios_base::badbit); output << value; buf.resize(buf.size()); @@ -104,7 +106,7 @@ struct fallback_formatter::value>> template auto format(const T& value, Context& ctx) -> decltype(ctx.out()) { basic_memory_buffer buffer; - format_value(buffer, value); + format_value(buffer, value, ctx.locale()); basic_string_view str(buffer.data(), buffer.size()); return formatter, Char>::format(str, ctx); }