summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--clang/Driver/clang.cpp3
-rw-r--r--clang/include/clang/Driver/TextDiagnosticPrinter.h11
-rw-r--r--clang/lib/Driver/TextDiagnosticPrinter.cpp15
3 files changed, 18 insertions, 11 deletions
diff --git a/clang/Driver/clang.cpp b/clang/Driver/clang.cpp
index 4314180c45e..ead873447bc 100644
--- a/clang/Driver/clang.cpp
+++ b/clang/Driver/clang.cpp
@@ -1443,7 +1443,8 @@ int main(int argc, char **argv) {
if (!VerifyDiagnostics) {
// Print diagnostics to stderr by default.
- TextDiagClient = new TextDiagnosticPrinter(!NoShowColumn,
+ TextDiagClient = new TextDiagnosticPrinter(llvm::errs(),
+ !NoShowColumn,
!NoCaretDiagnostics);
} else {
// When checking diagnostics, just buffer them up.
diff --git a/clang/include/clang/Driver/TextDiagnosticPrinter.h b/clang/include/clang/Driver/TextDiagnosticPrinter.h
index e5ef9fca824..e6d570c5e3b 100644
--- a/clang/include/clang/Driver/TextDiagnosticPrinter.h
+++ b/clang/include/clang/Driver/TextDiagnosticPrinter.h
@@ -17,7 +17,10 @@
#include "clang/Basic/Diagnostic.h"
#include "clang/Basic/SourceLocation.h"
-#include "llvm/Support/Streams.h"
+
+namespace llvm {
+ class raw_ostream;
+}
namespace clang {
class SourceManager;
@@ -25,12 +28,12 @@ class SourceManager;
class TextDiagnosticPrinter : public DiagnosticClient {
FullSourceLoc LastWarningLoc;
FullSourceLoc LastLoc;
- llvm::OStream OS;
+ llvm::raw_ostream &OS;
bool ShowColumn;
bool CaretDiagnostics;
public:
- TextDiagnosticPrinter(bool showColumn = true, bool caretDiagnistics = true,
- llvm::OStream &os = llvm::cerr)
+ TextDiagnosticPrinter(llvm::raw_ostream &os, bool showColumn = true,
+ bool caretDiagnistics = true)
: OS(os), ShowColumn(showColumn), CaretDiagnostics(caretDiagnistics) {}
void PrintIncludeStack(FullSourceLoc Pos);
diff --git a/clang/lib/Driver/TextDiagnosticPrinter.cpp b/clang/lib/Driver/TextDiagnosticPrinter.cpp
index cfbe8a7f927..b4be9307ea7 100644
--- a/clang/lib/Driver/TextDiagnosticPrinter.cpp
+++ b/clang/lib/Driver/TextDiagnosticPrinter.cpp
@@ -14,6 +14,7 @@
#include "clang/Driver/TextDiagnosticPrinter.h"
#include "clang/Basic/SourceManager.h"
#include "clang/Lex/Lexer.h"
+#include "llvm/Support/raw_ostream.h"
#include "llvm/Support/MemoryBuffer.h"
#include "llvm/ADT/SmallString.h"
using namespace clang;
@@ -29,7 +30,7 @@ PrintIncludeStack(FullSourceLoc Pos) {
unsigned LineNo = Pos.getLineNumber();
OS << "In file included from " << Pos.getSourceName()
- << ":" << LineNo << ":\n";
+ << ':' << LineNo << ":\n";
}
/// HighlightRange - Given a SourceRange and a line number, highlight (with ~'s)
@@ -127,10 +128,10 @@ void TextDiagnosticPrinter::HandleDiagnostic(Diagnostic::Level Level,
*LineEnd != '\n' && *LineEnd != '\r')
++LineEnd;
- OS << Buffer->getBufferIdentifier() << ":" << LineNo << ":";
+ OS << Buffer->getBufferIdentifier() << ':' << LineNo << ':';
if (ColNo && ShowColumn)
- OS << ColNo << ":";
- OS << " ";
+ OS << ColNo << ':';
+ OS << ' ';
}
switch (Level) {
@@ -193,7 +194,9 @@ void TextDiagnosticPrinter::HandleDiagnostic(Diagnostic::Level Level,
CaretLine.erase(CaretLine.end()-1);
// Emit what we have computed.
- OS << SourceLine << "\n";
- OS << CaretLine << "\n";
+ OS << SourceLine << '\n';
+ OS << CaretLine << '\n';
}
+
+ OS.flush();
}
OpenPOWER on IntegriCloud