]> granicus.if.org Git - clang/commitdiff
Fronted/CC_LOG_DIAGNOSTICS: Output main file name, and add support for
authorDaniel Dunbar <daniel@zuster.org>
Thu, 7 Apr 2011 18:51:54 +0000 (18:51 +0000)
committerDaniel Dunbar <daniel@zuster.org>
Thu, 7 Apr 2011 18:51:54 +0000 (18:51 +0000)
outputting dwarf-debug-flags.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@129094 91177308-0d34-0410-b5e6-96231b3b80d8

include/clang/Frontend/LogDiagnosticPrinter.h
lib/Frontend/LogDiagnosticPrinter.cpp

index 8ac6093318d260ec63da78577735a97130f5ab51..b6fc23ca1f048d4fa2c962496033375a4ddcd8c9 100644 (file)
@@ -12,6 +12,7 @@
 
 #include "clang/Basic/Diagnostic.h"
 #include "clang/Basic/SourceLocation.h"
+#include "llvm/ADT/StringRef.h"
 #include "llvm/ADT/SmallVector.h"
 
 namespace clang {
@@ -49,11 +50,18 @@ class LogDiagnosticPrinter : public DiagnosticClient {
 
   llvm::SmallVector<DiagEntry, 8> Entries;
 
+  std::string MainFilename;
+  std::string DwarfDebugFlags;
+
 public:
   LogDiagnosticPrinter(llvm::raw_ostream &OS, const DiagnosticOptions &Diags,
                        bool OwnsOutputStream = false);
   virtual ~LogDiagnosticPrinter();
 
+  void setDwarfDebugFlags(llvm::StringRef Value) {
+    DwarfDebugFlags = Value;
+  }
+
   void BeginSourceFile(const LangOptions &LO, const Preprocessor *PP) {
     LangOpts = &LO;
   }
index 9eee843dbe5c38c2461fe6be56ebdc06c6ba0b30..954bad4e7c54957a817799c08c09bb80b6392be7 100644 (file)
@@ -53,8 +53,14 @@ void LogDiagnosticPrinter::EndSourceFile() {
   llvm::raw_svector_ostream OS(Msg);
 
   OS << "<dict>\n";
-  // FIXME: Output main translation unit file name.
-  // FIXME: Include the invocation, if dwarf-debug-flags is available.
+  if (!MainFilename.empty()) {
+    OS << "  <key>main-file</key>\n"
+       << "  <string>" << MainFilename << "</string>\n";
+  }
+  if (!DwarfDebugFlags.empty()) {
+    OS << "  <key>dwarf-debug-flags</key>\n"
+       << "  <string>" << DwarfDebugFlags << "</string>\n";
+  }
   OS << "  <key>diagnostics</key>\n";
   OS << "  <array>\n";
   for (unsigned i = 0, e = Entries.size(); i != e; ++i) {
@@ -92,6 +98,17 @@ void LogDiagnosticPrinter::HandleDiagnostic(Diagnostic::Level Level,
   // Default implementation (Warnings/errors count).
   DiagnosticClient::HandleDiagnostic(Level, Info);
 
+  // Initialize the main file name, if we haven't already fetched it.
+  if (MainFilename.empty()) {
+    const SourceManager &SM = Info.getSourceManager();
+    FileID FID = SM.getMainFileID();
+    if (!FID.isInvalid()) {
+      const FileEntry *FE = SM.getFileEntryForID(FID);
+      if (FE && FE->getName())
+        MainFilename = FE->getName();
+    }
+  }
+
   // Create the diag entry.
   DiagEntry DE;
   DE.DiagnosticID = Info.getID();