Use qualified name-lookup in module. (#2324)

Allow lookup of non-exported names from local classes in function templates.
This commit is contained in:
Daniela Engert 2021-05-31 18:11:24 +02:00 committed by GitHub
parent bf9904ee4d
commit d7ba6c3ea8
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 4 additions and 2 deletions

View File

@ -298,7 +298,7 @@ inline auto do_write(const std::tm& time, const std::locale& loc, char format,
auto str = os.str(); auto str = os.str();
if (!detail::is_utf8() || loc == std::locale::classic()) return str; if (!detail::is_utf8() || loc == std::locale::classic()) return str;
// char16_t and char32_t codecvts are broken in MSVC (linkage errors). // char16_t and char32_t codecvts are broken in MSVC (linkage errors).
using code_unit = conditional_t<FMT_MSC_VER, wchar_t, char16_t>; using code_unit = conditional_t<FMT_MSC_VER != 0, wchar_t, char16_t>;
auto& f = std::use_facet<std::codecvt<code_unit, char, std::mbstate_t>>(loc); auto& f = std::use_facet<std::codecvt<code_unit, char, std::mbstate_t>>(loc);
auto mb = std::mbstate_t(); auto mb = std::mbstate_t();
const char* from_next = nullptr; const char* from_next = nullptr;
@ -1246,7 +1246,7 @@ struct formatter<std::chrono::duration<Rep, Period>, Char> {
ctx, out, d); ctx, out, d);
f.precision = precision_copy; f.precision = precision_copy;
f.localized = localized; f.localized = localized;
parse_chrono_format(begin, end, f); detail::parse_chrono_format(begin, end, f);
} }
return detail::write( return detail::write(
ctx.out(), basic_string_view<Char>(buf.data(), buf.size()), specs_copy); ctx.out(), basic_string_view<Char>(buf.data(), buf.size()), specs_copy);

View File

@ -2169,6 +2169,7 @@ FMT_CONSTEXPR FMT_INLINE auto parse_arg_id(const Char* begin, const Char* end,
template <typename Char, typename Handler> template <typename Char, typename Handler>
FMT_CONSTEXPR auto parse_width(const Char* begin, const Char* end, FMT_CONSTEXPR auto parse_width(const Char* begin, const Char* end,
Handler&& handler) -> const Char* { Handler&& handler) -> const Char* {
using detail::auto_id;
struct width_adapter { struct width_adapter {
Handler& handler; Handler& handler;
@ -2198,6 +2199,7 @@ FMT_CONSTEXPR auto parse_width(const Char* begin, const Char* end,
template <typename Char, typename Handler> template <typename Char, typename Handler>
FMT_CONSTEXPR auto parse_precision(const Char* begin, const Char* end, FMT_CONSTEXPR auto parse_precision(const Char* begin, const Char* end,
Handler&& handler) -> const Char* { Handler&& handler) -> const Char* {
using detail::auto_id;
struct precision_adapter { struct precision_adapter {
Handler& handler; Handler& handler;