Skip to content

Commit

Permalink
Disallow passing non-string-literals to FMT_STRING
Browse files Browse the repository at this point in the history
  • Loading branch information
vitaut committed Jan 23, 2020
1 parent 419db8b commit 09a1324
Show file tree
Hide file tree
Showing 2 changed files with 6 additions and 11 deletions.
14 changes: 6 additions & 8 deletions include/fmt/format.h
Original file line number Diff line number Diff line change
Expand Up @@ -3449,13 +3449,10 @@ template <typename Char> struct udl_arg {
}
};

// A constexpr version of strlen.
template <typename Char> FMT_CONSTEXPR size_t compute_length(const Char* s) {
size_t len = 0;
while (*s++) ++len;
return len;
template <typename Char, size_t N>
FMT_CONSTEXPR basic_string_view<Char> literal_to_view(const Char (&s)[N]) {
return {s, N - 1};
}

} // namespace internal

inline namespace literals {
Expand Down Expand Up @@ -3519,15 +3516,16 @@ FMT_END_NAMESPACE
using char_type = fmt::remove_cvref_t<decltype(*s)>; \
__VA_ARGS__ FMT_CONSTEXPR \
operator fmt::basic_string_view<char_type>() const { \
return {s, fmt::internal::compute_length(s)}; \
/* FMT_STRING only accepts string literals. */ \
return fmt::internal::literal_to_view(s); \
} \
}; \
return FMT_STRING(); \
}()

/**
\rst
Constructs a compile-time format string.
Constructs a compile-time format string from a string literal *s*.
**Example**::
Expand Down
3 changes: 0 additions & 3 deletions test/format-test.cc
Original file line number Diff line number Diff line change
Expand Up @@ -1849,10 +1849,7 @@ TEST(FormatTest, UnpackedArgs) {
struct string_like {};
fmt::string_view to_string_view(string_like) { return "foo"; }

FMT_CONSTEXPR_DECL const char* format_str_ptr = "0123456789";

TEST(FormatTest, CompileTimeString) {
EXPECT_EQ(format_str_ptr, fmt::format(FMT_STRING(format_str_ptr)));
EXPECT_EQ("42", fmt::format(FMT_STRING("{}"), 42));
EXPECT_EQ(L"42", fmt::format(FMT_STRING(L"{}"), 42));
EXPECT_EQ("foo", fmt::format(FMT_STRING("{}"), string_like()));
Expand Down

0 comments on commit 09a1324

Please sign in to comment.