Fronted/CC_LOG_DIAGNOSTICS: Tweak output form to be plist chunks, and don't

output missing data.

llvm-svn: 129093
This commit is contained in:
Daniel Dunbar 2011-04-07 18:44:15 +00:00
parent 64beb47783
commit 719393a56b
1 changed files with 25 additions and 11 deletions

View File

@ -52,23 +52,37 @@ void LogDiagnosticPrinter::EndSourceFile() {
llvm::SmallString<512> Msg;
llvm::raw_svector_ostream OS(Msg);
OS << "{\n";
OS << "<dict>\n";
// FIXME: Output main translation unit file name.
// FIXME: Include the invocation, if dwarf-debug-flags is available.
OS << " \"diagnostics\" : [\n";
OS << " <key>diagnostics</key>\n";
OS << " <array>\n";
for (unsigned i = 0, e = Entries.size(); i != e; ++i) {
DiagEntry &DE = Entries[i];
OS << " {\n";
OS << " \"filename\" : \"" << DE.Filename << "\",\n";
OS << " \"line\" : " << DE.Line << ",\n";
OS << " \"column\" : " << DE.Column << ",\n";
OS << " \"message\" : \"" << DE.Message << "\",\n";
OS << " \"level\" : \"" << getLevelName(DE.DiagnosticLevel) << "\"\n";
OS << " }" << ((i + 1 != e) ? "," : "") << '\n';
OS << " <dict>\n";
OS << " <key>level</key>\n"
<< " <string>" << getLevelName(DE.DiagnosticLevel) << "</string>\n";
if (!DE.Filename.empty()) {
OS << " <key>filename</key>\n"
<< " <string>" << DE.Filename << "</string>\n";
}
if (DE.Line != 0) {
OS << " <key>line</key>\n"
<< " <integer>" << DE.Line << "</integer>\n";
}
if (DE.Column != 0) {
OS << " <key>column</key>\n"
<< " <integer>" << DE.Column << "</integer>\n";
}
if (!DE.Message.empty()) {
OS << " <key>message</key>\n"
<< " <string>" << DE.Message << "</string>\n";
}
OS << " </dict>\n";
}
OS << " ]\n";
OS << "},\n";
OS << " </array>\n";
OS << "</dict>\n";
this->OS << OS.str();
}