summaryrefslogtreecommitdiff
path: root/include/llvm/Support/FormattedStream.h
diff options
context:
space:
mode:
authorDan Gohman <gohman@apple.com>2009-08-13 23:16:59 +0000
committerDan Gohman <gohman@apple.com>2009-08-13 23:16:59 +0000
commit6c304f2314e5fb00488ac6bdfdac180c0ffd3d09 (patch)
treed6f6c33489a410db659ede1f8b0b230eb691b5d5 /include/llvm/Support/FormattedStream.h
parent009fc9e5d9058a1d3b64bf5cacb29d4f0c952ca5 (diff)
downloadllvm-6c304f2314e5fb00488ac6bdfdac180c0ffd3d09.tar.gz
llvm-6c304f2314e5fb00488ac6bdfdac180c0ffd3d09.tar.bz2
llvm-6c304f2314e5fb00488ac6bdfdac180c0ffd3d09.tar.xz
Make formatted_raw_ostream restore the buffer settings of the
underlying stream when it is finished, so that clients don't have to do this manually. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@78952 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'include/llvm/Support/FormattedStream.h')
-rw-r--r--include/llvm/Support/FormattedStream.h24
1 files changed, 19 insertions, 5 deletions
diff --git a/include/llvm/Support/FormattedStream.h b/include/llvm/Support/FormattedStream.h
index 11a0e18db4..a74ee6f7d9 100644
--- a/include/llvm/Support/FormattedStream.h
+++ b/include/llvm/Support/FormattedStream.h
@@ -101,13 +101,11 @@ namespace llvm
~formatted_raw_ostream() {
flush();
- if (DeleteStream)
- delete TheStream;
+ releaseStream();
}
-
+
void setStream(raw_ostream &Stream, bool Delete = false) {
- if (DeleteStream)
- delete TheStream;
+ releaseStream();
TheStream = &Stream;
DeleteStream = Delete;
@@ -118,6 +116,8 @@ namespace llvm
// had been using, and tell TheStream not to do its own buffering.
if (size_t BufferSize = TheStream->GetBufferSize())
SetBufferSize(BufferSize);
+ else
+ SetUnbuffered();
TheStream->SetUnbuffered();
Scanned = begin();
@@ -130,6 +130,20 @@ namespace llvm
/// recent I/O, even if the current column + minpad > newcol.
///
void PadToColumn(unsigned NewCol, unsigned MinPad = 0);
+
+ private:
+ void releaseStream() {
+ // Delete the stream if needed. Otherwise, transfer the buffer
+ // settings from this raw_ostream back to the underlying stream.
+ if (!TheStream)
+ return;
+ if (DeleteStream)
+ delete TheStream;
+ else if (size_t BufferSize = GetBufferSize())
+ TheStream->SetBufferSize(BufferSize);
+ else
+ TheStream->SetUnbuffered();
+ }
};
/// fouts() - This returns a reference to a formatted_raw_ostream for