raw_ostream: If writing a string that is larger than the buffer, write it directly instead of doing many buffer-sized writes.

This caps the number of write(2) calls per string to a maximum of 2.

llvm-svn: 127010
This commit is contained in:
Benjamin Kramer 2011-03-04 18:18:16 +00:00
parent 3b83d63a17
commit acf0842088
1 changed files with 13 additions and 9 deletions

View File

@ -265,15 +265,19 @@ raw_ostream &raw_ostream::write(const char *Ptr, size_t Size) {
return write(Ptr, Size);
}
// Write out the data in buffer-sized blocks until the remainder
// fits within the buffer.
do {
size_t NumBytes = OutBufEnd - OutBufCur;
copy_to_buffer(Ptr, NumBytes);
flush_nonempty();
Ptr += NumBytes;
Size -= NumBytes;
} while (OutBufCur+Size > OutBufEnd);
// If the buffer is empty at this point we have a string that is larger
// than the buffer. It's better to write it unbuffered in this case.
if (BUILTIN_EXPECT(OutBufCur == OutBufStart, false)) {
write_impl(Ptr, Size);
return *this;
}
// We don't have enough space in the buffer to fit the string in. Insert as
// much as possible, flush and start over with the remainder.
size_t NumBytes = OutBufEnd - OutBufCur;
copy_to_buffer(Ptr, NumBytes);
flush_nonempty();
return write(Ptr + NumBytes, Size - NumBytes);
}
copy_to_buffer(Ptr, Size);