diff options
author | Dan Gohman <gohman@apple.com> | 2009-08-13 23:16:59 +0000 |
---|---|---|
committer | Dan Gohman <gohman@apple.com> | 2009-08-13 23:16:59 +0000 |
commit | 6c304f2314e5fb00488ac6bdfdac180c0ffd3d09 (patch) | |
tree | d6f6c33489a410db659ede1f8b0b230eb691b5d5 /include/llvm/Support/FormattedStream.h | |
parent | 009fc9e5d9058a1d3b64bf5cacb29d4f0c952ca5 (diff) |
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.h | 24 |
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 |