diff options
| author | Chandler Carruth <chandlerc@gmail.com> | 2011-09-26 00:21:47 +0000 | 
|---|---|---|
| committer | Chandler Carruth <chandlerc@gmail.com> | 2011-09-26 00:21:47 +0000 | 
| commit | b7e3f42a0160e8639c368807dc514826090f175c (patch) | |
| tree | e81c8eb3558f7d9357ae4f06316bbd72361954c5 /clang/lib/Frontend | |
| parent | f18d91a4b21ba817db97c61a7ae84e9f8377557c (diff) | |
| download | bcm5719-llvm-b7e3f42a0160e8639c368807dc514826090f175c.tar.gz bcm5719-llvm-b7e3f42a0160e8639c368807dc514826090f175c.zip | |
Extract the diagnostic message formatting into a helper routine.
llvm-svn: 140484
Diffstat (limited to 'clang/lib/Frontend')
| -rw-r--r-- | clang/lib/Frontend/TextDiagnosticPrinter.cpp | 73 | 
1 files changed, 39 insertions, 34 deletions
| diff --git a/clang/lib/Frontend/TextDiagnosticPrinter.cpp b/clang/lib/Frontend/TextDiagnosticPrinter.cpp index a947c0e80ea..c6b1df9c77f 100644 --- a/clang/lib/Frontend/TextDiagnosticPrinter.cpp +++ b/clang/lib/Frontend/TextDiagnosticPrinter.cpp @@ -1086,39 +1086,9 @@ static void PrintDiagnosticLevel(raw_ostream& OS,      OS.resetColor();  } -void TextDiagnosticPrinter::HandleDiagnostic(DiagnosticsEngine::Level Level, -                                             const DiagnosticInfo &Info) { -  // Default implementation (Warnings/errors count). -  DiagnosticConsumer::HandleDiagnostic(Level, Info); - -  // Keeps track of the the starting position of the location -  // information (e.g., "foo.c:10:4:") that precedes the error -  // message. We use this information to determine how long the -  // file+line+column number prefix is. -  uint64_t StartOfLocationInfo = OS.tell(); - -  if (!Prefix.empty()) -    OS << Prefix << ": "; - -  if (Info.getLocation().isValid()) { -    const SourceManager &SM = Info.getSourceManager(); -    PresumedLoc PLoc = getDiagnosticPresumedLoc(SM, Info.getLocation()); - -    // First, if this diagnostic is not in the main file, print out the -    // "included from" lines. -    PrintIncludeStack(Level, PLoc.getIncludeLoc(), SM); -    StartOfLocationInfo = OS.tell(); - -    // Next emit the location of this particular diagnostic. -    EmitDiagnosticLoc(Level, Info, SM, PLoc); - -    if (DiagOpts->ShowColors) -      OS.resetColor(); -  } - -  PrintDiagnosticLevel(OS, Level, DiagOpts->ShowColors); - -  llvm::SmallString<100> OutStr; +static void FormatDiagnosticMessage(const Diagnostic &Info, +                                    const DiagnosticOptions &DiagOpts, +                                    SmallVectorImpl<char> &OutStr) {    Info.FormatDiagnostic(OutStr);    if (DiagOpts->ShowNames && @@ -1186,8 +1156,43 @@ void TextDiagnosticPrinter::HandleDiagnostic(DiagnosticsEngine::Level Level,      OutStr += "]";    } +} + +void TextDiagnosticPrinter::HandleDiagnostic(DiagnosticsEngine::Level Level, +                                             const DiagnosticInfo &Info) { +  // Default implementation (Warnings/errors count). +  DiagnosticConsumer::HandleDiagnostic(Level, Info); + +  // Keeps track of the the starting position of the location +  // information (e.g., "foo.c:10:4:") that precedes the error +  // message. We use this information to determine how long the +  // file+line+column number prefix is. +  uint64_t StartOfLocationInfo = OS.tell(); + +  if (!Prefix.empty()) +    OS << Prefix << ": "; + +  if (Info.getLocation().isValid()) { +    const SourceManager &SM = Info.getSourceManager(); +    PresumedLoc PLoc = getDiagnosticPresumedLoc(SM, Info.getLocation()); + +    // First, if this diagnostic is not in the main file, print out the +    // "included from" lines. +    PrintIncludeStack(Level, PLoc.getIncludeLoc(), SM); +    StartOfLocationInfo = OS.tell(); + +    // Next emit the location of this particular diagnostic. +    EmitDiagnosticLoc(Level, Info, SM, PLoc); + +    if (DiagOpts->ShowColors) +      OS.resetColor(); +  } + +  PrintDiagnosticLevel(OS, Level, DiagOpts->ShowColors); + +  llvm::SmallString<100> OutStr; +  FormatDiagnosticMessage(Info, *Diagopts, OutStr); -      if (DiagOpts->ShowColors) {      // Print warnings, errors and fatal errors in bold, no color      switch (Level) { | 

