From 287eaab3b2777daa5d0d0cf72d977196ba54efb7 Mon Sep 17 00:00:00 2001 From: Alexander Bolz Date: Tue, 26 Feb 2019 20:38:03 +0100 Subject: [PATCH] Increment output iterator in basic_writer::write for character types (#1056) --- include/fmt/format.h | 8 ++++++-- test/format-test.cc | 22 ++++++++++++++++++++++ 2 files changed, 28 insertions(+), 2 deletions(-) diff --git a/include/fmt/format.h b/include/fmt/format.h index 317597ca..44584c10 100644 --- a/include/fmt/format.h +++ b/include/fmt/format.h @@ -2755,10 +2755,14 @@ template class basic_writer { void write(long double value) { write_double(value, format_specs()); } /** Writes a character to the buffer. */ - void write(char value) { *reserve(1) = value; } + void write(char value) { + auto&& it = reserve(1); + *it++ = value; + } void write(wchar_t value) { static_assert(std::is_same::value, ""); - *reserve(1) = value; + auto&& it = reserve(1); + *it++ = value; } /** diff --git a/test/format-test.cc b/test/format-test.cc index eed34141..822557b7 100644 --- a/test/format-test.cc +++ b/test/format-test.cc @@ -2040,6 +2040,17 @@ TEST(FormatTest, FormatToN) { EXPECT_EQ(6u, result.size); EXPECT_EQ(buffer + 3, result.out); EXPECT_EQ("foox", fmt::string_view(buffer, 4)); + buffer[0] = 'x'; + buffer[1] = 'x'; + buffer[2] = 'x'; + result = fmt::format_to_n(buffer, 3, "{}", 'A'); + EXPECT_EQ(1u, result.size); + EXPECT_EQ(buffer + 1, result.out); + EXPECT_EQ("Axxx", fmt::string_view(buffer, 4)); + result = fmt::format_to_n(buffer, 3, "{}{} ", 'B', 'C'); + EXPECT_EQ(3u, result.size); + EXPECT_EQ(buffer + 3, result.out); + EXPECT_EQ("BC x", fmt::string_view(buffer, 4)); } TEST(FormatTest, WideFormatToN) { @@ -2049,6 +2060,17 @@ TEST(FormatTest, WideFormatToN) { EXPECT_EQ(5u, result.size); EXPECT_EQ(buffer + 3, result.out); EXPECT_EQ(L"123x", fmt::wstring_view(buffer, 4)); + buffer[0] = L'x'; + buffer[1] = L'x'; + buffer[2] = L'x'; + result = fmt::format_to_n(buffer, 3, L"{}", L'A'); + EXPECT_EQ(1u, result.size); + EXPECT_EQ(buffer + 1, result.out); + EXPECT_EQ(L"Axxx", fmt::wstring_view(buffer, 4)); + result = fmt::format_to_n(buffer, 3, L"{}{} ", L'B', L'C'); + EXPECT_EQ(3u, result.size); + EXPECT_EQ(buffer + 3, result.out); + EXPECT_EQ(L"BC x", fmt::wstring_view(buffer, 4)); } #if FMT_USE_CONSTEXPR