mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-12-12 14:06:36 +00:00
Changes to fix buffering that I forgot to commit with previous patch.
llvm-svn: 94222
This commit is contained in:
parent
bc2e117803
commit
639c136993
@ -456,8 +456,10 @@ public:
|
||||
explicit raw_svector_ostream(SmallVectorImpl<char> &O);
|
||||
~raw_svector_ostream();
|
||||
|
||||
/// clear - Flush the stream and clear the underlying vector.
|
||||
void clear();
|
||||
/// resync - This is called when the SmallVector we're appending to is changed
|
||||
/// outside of the raw_svector_ostream's control. It is only safe to do this
|
||||
/// if the raw_svector_ostream has previously been flushed.
|
||||
void resync();
|
||||
|
||||
/// str - Flushes the stream contents to the target vector and return a
|
||||
/// StringRef for the vector contents.
|
||||
|
@ -136,6 +136,9 @@ void MCAsmStreamer::AddComment(const Twine &T) {
|
||||
T.toVector(CommentToEmit);
|
||||
// Each comment goes on its own line.
|
||||
CommentToEmit.push_back('\n');
|
||||
|
||||
// Tell the comment stream that the vector changed underneath it.
|
||||
CommentStream.resync();
|
||||
}
|
||||
|
||||
void MCAsmStreamer::EmitCommentsAndEOL() {
|
||||
@ -158,7 +161,9 @@ void MCAsmStreamer::EmitCommentsAndEOL() {
|
||||
Comments = Comments.substr(Position+1);
|
||||
} while (!Comments.empty());
|
||||
|
||||
CommentStream.clear();
|
||||
CommentToEmit.clear();
|
||||
// Tell the comment stream that the vector changed underneath it.
|
||||
CommentStream.resync();
|
||||
}
|
||||
|
||||
|
||||
|
@ -562,11 +562,14 @@ raw_svector_ostream::~raw_svector_ostream() {
|
||||
flush();
|
||||
}
|
||||
|
||||
/// clear - Flush the stream and clear the underlying vector.
|
||||
void raw_svector_ostream::clear() {
|
||||
if (GetNumBytesInBuffer() == 0) flush();
|
||||
|
||||
OS.clear();
|
||||
/// resync - This is called when the SmallVector we're appending to is changed
|
||||
/// outside of the raw_svector_ostream's control. It is only safe to do this
|
||||
/// if the raw_svector_ostream has previously been flushed.
|
||||
void raw_svector_ostream::resync() {
|
||||
assert(GetNumBytesInBuffer() == 0 && "Didn't flush before mutating vector");
|
||||
|
||||
if (OS.capacity() - OS.size() < 64)
|
||||
OS.reserve(OS.capacity() * 2);
|
||||
SetBuffer(OS.end(), OS.capacity() - OS.size());
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user