mirror of
https://github.com/fmtlib/fmt.git
synced 2025-01-13 18:39:35 +00:00
Add move ctor to BasicWriter.
This commit is contained in:
parent
259a307daf
commit
08b0741fa7
@ -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;
|
||||||
|
9
format.h
9
format.h
@ -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.
|
||||||
*/
|
*/
|
||||||
|
Loading…
Reference in New Issue
Block a user