Add move ctor to BasicWriter.

This commit is contained in:
Victor Zverovich 2014-04-25 07:40:37 -07:00
parent 259a307daf
commit 08b0741fa7
2 changed files with 59 additions and 23 deletions

View File

@ -209,34 +209,32 @@ TEST(ArrayTest, Ctor) {
#if FMT_USE_RVALUE_REFERENCES #if FMT_USE_RVALUE_REFERENCES
void CheckMoveArray(const char *str, Array<char, 5> &array) {
Array<char, 5> array2(std::move(array));
// Move shouldn't destroy the inline content of the first array.
EXPECT_EQ(str, std::string(&array[0], array.size()));
EXPECT_EQ(str, std::string(&array2[0], array2.size()));
EXPECT_EQ(5, array2.capacity());
}
TEST(ArrayTest, MoveCtor) { TEST(ArrayTest, MoveCtor) {
Array<char, 5> array; Array<char, 5> array;
const char test[] = "test"; const char test[] = "test";
array.append(test, test + 4); array.append(test, test + 4);
{ CheckMoveArray("test", array);
Array<char, 5> array2(std::move(array)); // Adding one more character fills the inline buffer, but doesn't cause
// Moving shouldn't destroy the inline content of the first array. // dynamic allocation.
EXPECT_EQ(test, std::string(&array[0], array.size()));
EXPECT_EQ(test, std::string(&array2[0], array2.size()));
EXPECT_EQ(5, array2.capacity());
}
array.push_back('a'); array.push_back('a');
{ CheckMoveArray("testa", array);
Array<char, 5> array2(std::move(array)); // Adding one more character causes the content to move from the inline to
// Moving shouldn't destroy the inline content of the first array. // a dynamically allocated buffer.
EXPECT_EQ("testa", std::string(&array[0], array.size()));
EXPECT_EQ("testa", std::string(&array2[0], array2.size()));
EXPECT_EQ(5, array2.capacity());
}
array.push_back('b'); array.push_back('b');
{
Array<char, 5> array2(std::move(array)); Array<char, 5> array2(std::move(array));
// Moving should rip the guts of the first array. // Move should rip the guts of the first array.
EXPECT_TRUE(!&array[0]); EXPECT_TRUE(!&array[0]);
EXPECT_EQ("testab", std::string(&array2[0], array2.size())); EXPECT_EQ("testab", std::string(&array2[0], array2.size()));
EXPECT_GT(array2.capacity(), 5); EXPECT_GT(array2.capacity(), 5);
} }
}
#endif // FMT_USE_RVALUE_REFERENCES #endif // FMT_USE_RVALUE_REFERENCES
@ -317,6 +315,37 @@ TEST(WriterTest, Ctor) {
EXPECT_EQ("", w.str()); EXPECT_EQ("", w.str());
} }
#if FMT_USE_RVALUE_REFERENCES
void CheckMoveWriter(const std::string &str, Writer &w) {
Writer w2(std::move(w));
// Move shouldn't destroy the inline content of the first writer.
EXPECT_EQ(str, w.str());
EXPECT_EQ(str, w2.str());
}
TEST(WriterTest, MoveCtor) {
Writer w;
w << "test";
CheckMoveWriter("test", w);
// This fills the inline buffer, but doesn't cause dynamic allocation.
std::string s;
for (int i = 0; i < fmt::internal::INLINE_BUFFER_SIZE; ++i)
s += '*';
w.Clear();
w << s;
CheckMoveWriter(s, w);
// Adding one more character causes the content to move from the inline to
// a dynamically allocated buffer.
w << '*';
Writer w2(std::move(w));
// Move should rip the guts of the first writer.
EXPECT_TRUE(!w.data());
EXPECT_EQ(s + '*', w2.str());
}
#endif // FMT_USE_RVALUE_REFERENCES
TEST(WriterTest, Data) { TEST(WriterTest, Data) {
Writer w; Writer w;
w << 42; w << 42;

View File

@ -693,7 +693,8 @@ inline StrFormatSpec<wchar_t> pad(
template <typename Char> template <typename Char>
class BasicWriter { class BasicWriter {
private: private:
mutable internal::Array<Char, internal::INLINE_BUFFER_SIZE> buffer_; // Output buffer. // Output buffer.
mutable internal::Array<Char, internal::INLINE_BUFFER_SIZE> buffer_;
// Make BasicFormatter a friend so that it can access ArgInfo and Arg. // Make BasicFormatter a friend so that it can access ArgInfo and Arg.
friend class BasicFormatter<Char>; friend class BasicFormatter<Char>;
@ -898,6 +899,12 @@ class BasicWriter {
}; };
public: public:
BasicWriter() {}
#if FMT_USE_RVALUE_REFERENCES
BasicWriter(BasicWriter &&other) : buffer_(std::move(other.buffer_)) {}
#endif
/** /**
Returns the number of characters written to the output buffer. Returns the number of characters written to the output buffer.
*/ */