From daaa8b720b026c83bf6d4307042057665348b222 Mon Sep 17 00:00:00 2001 From: Yuchen Wu Date: Sat, 2 Nov 2013 00:09:17 +0000 Subject: Added command-line option to output llvm-cov to file. Added -o option to llvm-cov. If no output file is specified, it defaults to STDOUT. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@193899 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/llvm/Support/GCOV.h | 2 +- lib/IR/GCOV.cpp | 21 +++++++++++---------- tools/llvm-cov/llvm-cov.cpp | 11 ++++++++++- 3 files changed, 22 insertions(+), 12 deletions(-) diff --git a/include/llvm/Support/GCOV.h b/include/llvm/Support/GCOV.h index ef1a4eb..d8836e0 100644 --- a/include/llvm/Support/GCOV.h +++ b/include/llvm/Support/GCOV.h @@ -235,7 +235,7 @@ public: LineInfo[Filename][Line-1] += Count; } void setProgramCount(uint32_t PC) { ProgramCount = PC; } - void print(StringRef gcnoFile, StringRef gcdaFile); + void print(raw_fd_ostream &OS, StringRef gcnoFile, StringRef gcdaFile); private: StringMap LineInfo; uint32_t ProgramCount; diff --git a/lib/IR/GCOV.cpp b/lib/IR/GCOV.cpp index 7c9cfe3..794ead9 100644 --- a/lib/IR/GCOV.cpp +++ b/lib/IR/GCOV.cpp @@ -250,14 +250,15 @@ void GCOVLines::dump() { // FileInfo implementation. /// print - Print source files with collected line count information. -void FileInfo::print(StringRef gcnoFile, StringRef gcdaFile) { +void FileInfo::print(raw_fd_ostream &OS, StringRef gcnoFile, + StringRef gcdaFile) { for (StringMap::iterator I = LineInfo.begin(), E = LineInfo.end(); I != E; ++I) { StringRef Filename = I->first(); - outs() << " -: 0:Source:" << Filename << "\n"; - outs() << " -: 0:Graph:" << gcnoFile << "\n"; - outs() << " -: 0:Data:" << gcdaFile << "\n"; - outs() << " -: 0:Programs:" << ProgramCount << "\n"; + OS << " -: 0:Source:" << Filename << "\n"; + OS << " -: 0:Graph:" << gcnoFile << "\n"; + OS << " -: 0:Data:" << gcdaFile << "\n"; + OS << " -: 0:Programs:" << ProgramCount << "\n"; LineCounts &L = LineInfo[Filename]; OwningPtr Buff; if (error_code ec = MemoryBuffer::getFileOrSTDIN(Filename, Buff)) { @@ -269,16 +270,16 @@ void FileInfo::print(StringRef gcnoFile, StringRef gcdaFile) { while (!AllLines.empty()) { if (L.find(i) != L.end()) { if (L[i] == 0) - outs() << " #####:"; + OS << " #####:"; else - outs() << format("%9lu:", L[i]); + OS << format("%9lu:", L[i]); } else { - outs() << " -:"; + OS << " -:"; } std::pair P = AllLines.split('\n'); if (AllLines != P.first) - outs() << format("%5u:", i+1) << P.first; - outs() << "\n"; + OS << format("%5u:", i+1) << P.first; + OS << "\n"; AllLines = P.second; ++i; } diff --git a/tools/llvm-cov/llvm-cov.cpp b/tools/llvm-cov/llvm-cov.cpp index 4a69c71..ad6c671 100644 --- a/tools/llvm-cov/llvm-cov.cpp +++ b/tools/llvm-cov/llvm-cov.cpp @@ -17,6 +17,7 @@ #include "llvm/Support/ManagedStatic.h" #include "llvm/Support/MemoryObject.h" #include "llvm/Support/PrettyStackTrace.h" +#include "llvm/Support/raw_ostream.h" #include "llvm/Support/Signals.h" #include "llvm/Support/system_error.h" using namespace llvm; @@ -30,6 +31,9 @@ InputGCNO("gcno", cl::desc(""), cl::init("")); static cl::opt InputGCDA("gcda", cl::desc(""), cl::init("")); +static cl::opt +OutputFile("o", cl::desc(""), cl::init("-")); + //===----------------------------------------------------------------------===// int main(int argc, char **argv) { @@ -40,6 +44,11 @@ int main(int argc, char **argv) { cl::ParseCommandLineOptions(argc, argv, "llvm coverage tool\n"); + std::string ErrorInfo; + raw_fd_ostream OS(OutputFile.c_str(), ErrorInfo); + if (!ErrorInfo.empty()) + errs() << ErrorInfo << "\n"; + GCOVFile GF; if (InputGCNO.empty()) errs() << " " << argv[0] << ": No gcov input file!\n"; @@ -74,6 +83,6 @@ int main(int argc, char **argv) { FileInfo FI; GF.collectLineCounts(FI); - FI.print(InputGCNO, InputGCDA); + FI.print(OS, InputGCNO, InputGCDA); return 0; } -- cgit v1.1