Change raw_svector_ostream to reserve the input buffer if necessary, Ted was

right.
 - This class turns out to be much more convenient to use if we do this; clients
   can make sure the buffer is always big enough if they care (since our current
   idiom tends to be to use a SmallString<256> for the input to this we should
   generally be avoiding an unnecessary malloc).

Also, add a convenience raw_svector_ostream::str method which flushes the buffer
and returns a StringRef for the vector contents.

llvm-svn: 79446
This commit is contained in:
Daniel Dunbar 2009-08-19 18:40:58 +00:00
parent 45e5670ede
commit e813cbaa21
2 changed files with 13 additions and 5 deletions

View File

@ -454,10 +454,14 @@ class raw_svector_ostream : public raw_ostream {
public: public:
/// Construct a new raw_svector_ostream. /// Construct a new raw_svector_ostream.
/// ///
/// \arg O - The vector to write to; this *must* have at least 128 bytes of /// \arg O - The vector to write to; this should generally have at least 128
/// free space in it. /// bytes free to avoid any extraneous memory overhead.
explicit raw_svector_ostream(SmallVectorImpl<char> &O); explicit raw_svector_ostream(SmallVectorImpl<char> &O);
~raw_svector_ostream(); ~raw_svector_ostream();
/// str - Flushes the stream contents to the target vector and return a
/// StringRef for the vector contents.
StringRef str();
}; };
/// raw_null_ostream - A raw_ostream that discards all output. /// raw_null_ostream - A raw_ostream that discards all output.

View File

@ -487,12 +487,11 @@ void raw_string_ostream::write_impl(const char *Ptr, size_t Size) {
// and we only need to set the vector size when the data is flushed. // and we only need to set the vector size when the data is flushed.
raw_svector_ostream::raw_svector_ostream(SmallVectorImpl<char> &O) : OS(O) { raw_svector_ostream::raw_svector_ostream(SmallVectorImpl<char> &O) : OS(O) {
// Set up the initial external buffer. We enforce that the buffer must have at // Set up the initial external buffer. We make sure that the buffer has at
// least 128 bytes free; raw_ostream itself only requires 64, but we want to // least 128 bytes free; raw_ostream itself only requires 64, but we want to
// make sure that we don't grow the buffer unnecessarily on destruction (when // make sure that we don't grow the buffer unnecessarily on destruction (when
// the data is flushed). See the FIXME below. // the data is flushed). See the FIXME below.
if (OS.capacity() - OS.size() < 128) OS.reserve(OS.size() + 128);
llvm_report_error("Invalid argument, must have at least 128 bytes free!");
SetBuffer(OS.end(), OS.capacity() - OS.size()); SetBuffer(OS.end(), OS.capacity() - OS.size());
} }
@ -519,6 +518,11 @@ void raw_svector_ostream::write_impl(const char *Ptr, size_t Size) {
uint64_t raw_svector_ostream::current_pos() { return OS.size(); } uint64_t raw_svector_ostream::current_pos() { return OS.size(); }
StringRef raw_svector_ostream::str() {
flush();
return StringRef(OS.begin(), OS.size());
}
//===----------------------------------------------------------------------===// //===----------------------------------------------------------------------===//
// raw_null_ostream // raw_null_ostream
//===----------------------------------------------------------------------===// //===----------------------------------------------------------------------===//