mirror of
https://github.com/fmtlib/fmt.git
synced 2024-11-27 20:40:06 +00:00
change type naming and fix sfinae bug
This commit is contained in:
parent
b98e8301d5
commit
2dea780fbd
@ -472,10 +472,10 @@ struct compile_string {};
|
||||
template <typename S>
|
||||
struct is_compile_string : std::is_base_of<compile_string, S> {};
|
||||
|
||||
template <typename S, typename Enable = std::enable_if<is_compile_string<S>::value>>
|
||||
inline auto to_string_view(const S &s) -> basic_string_view<typename S::Char> {
|
||||
typedef typename S::Char Char;
|
||||
return basic_string_view<Char>{s.data(), s.size() - 1};
|
||||
template <typename S, typename Enable = typename std::enable_if<is_compile_string<S>::value>::type>
|
||||
inline auto to_string_view(const S &s) -> basic_string_view<typename S::char_type> {
|
||||
typedef typename S::char_type char_type;
|
||||
return basic_string_view<char_type>{s.data(), s.size() - 1};
|
||||
}
|
||||
|
||||
template <typename Context>
|
||||
|
@ -2243,10 +2243,10 @@ FMT_CONSTEXPR bool check_format_string(
|
||||
template <typename... Args, typename String>
|
||||
typename std::enable_if<is_compile_string<String>::value>::type
|
||||
check_format_string(String format_str) {
|
||||
typedef typename String::Char Char;
|
||||
typedef typename String::char_type char_type;
|
||||
FMT_CONSTEXPR_DECL bool invalid_format =
|
||||
internal::check_format_string<Char, internal::error_handler, Args...>(
|
||||
basic_string_view<Char>(format_str.data(), format_str.size()));
|
||||
internal::check_format_string<char_type, internal::error_handler, Args...>(
|
||||
basic_string_view<char_type>(format_str.data(), format_str.size()));
|
||||
(void)invalid_format;
|
||||
}
|
||||
|
||||
@ -3598,10 +3598,10 @@ FMT_END_NAMESPACE
|
||||
#define FMT_STRING(s) [] { \
|
||||
typedef typename std::decay<decltype(s)>::type pointer; \
|
||||
struct S : fmt::compile_string { \
|
||||
typedef typename std::remove_cv<std::remove_pointer<pointer>::type>::type Char;\
|
||||
typedef typename std::remove_cv<std::remove_pointer<pointer>::type>::type char_type;\
|
||||
static FMT_CONSTEXPR pointer data() { return s; } \
|
||||
static FMT_CONSTEXPR size_t size() { return sizeof(s) / sizeof(Char); } \
|
||||
explicit operator fmt::basic_string_view<Char>() const { return s; } \
|
||||
static FMT_CONSTEXPR size_t size() { return sizeof(s) / sizeof(char_type); } \
|
||||
explicit operator fmt::basic_string_view<char_type>() const { return s; } \
|
||||
}; \
|
||||
return S{}; \
|
||||
}()
|
||||
|
@ -2380,8 +2380,8 @@ TEST(FormatTest, VFormatTo) {
|
||||
fmt::vformat_to(std::back_inserter(w), L"{}", wargs);
|
||||
EXPECT_EQ(L"42", w);
|
||||
w.clear();
|
||||
fmt::vformat_to(std::back_inserter(w), FMT_STRING(L"{}"), args);
|
||||
EXPECT_EQ("42", w);
|
||||
fmt::vformat_to(std::back_inserter(w), FMT_STRING(L"{}"), wargs);
|
||||
EXPECT_EQ(L"42", w);
|
||||
}
|
||||
|
||||
#endif // FMT_USE_CONSTEXPR
|
||||
|
Loading…
Reference in New Issue
Block a user