summaryrefslogtreecommitdiff
path: root/lib/IR/GCOV.cpp
diff options
context:
space:
mode:
authorYuchen Wu <yuchenericwu@hotmail.com>2013-10-23 19:45:03 +0000
committerYuchen Wu <yuchenericwu@hotmail.com>2013-10-23 19:45:03 +0000
commit9db9663d1d2e4e336c2787bacff4ee7125622e21 (patch)
tree652abc47085c02c07ced5c8cf14ffdff53940a45 /lib/IR/GCOV.cpp
parent1e0437804c084dabda8894508f5867fdfb4df915 (diff)
downloadllvm-9db9663d1d2e4e336c2787bacff4ee7125622e21.tar.gz
llvm-9db9663d1d2e4e336c2787bacff4ee7125622e21.tar.bz2
llvm-9db9663d1d2e4e336c2787bacff4ee7125622e21.tar.xz
Use a map instead of vector to store line counts.
There are a few motivations for this: - Using a map allows for checking if line is in map. This differentiates unexecutable lines (such as comments) from unexecuted logical lines of code. "#####" is now outputted in this case, in line with gcov. - Source files are no longer read in twice: once when storing the line counts, and once when outputting the data. - Greatly simplifies the function FileInfo::addLineCount(). git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@193264 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/IR/GCOV.cpp')
-rw-r--r--lib/IR/GCOV.cpp32
1 files changed, 10 insertions, 22 deletions
diff --git a/lib/IR/GCOV.cpp b/lib/IR/GCOV.cpp
index f810d37775..68b91e6dc9 100644
--- a/lib/IR/GCOV.cpp
+++ b/lib/IR/GCOV.cpp
@@ -235,24 +235,6 @@ void GCOVLines::dump() {
//===----------------------------------------------------------------------===//
// FileInfo implementation.
-/// addLineCount - Add line count for the given line number in a file.
-void FileInfo::addLineCount(StringRef Filename, uint32_t Line, uint64_t Count) {
- if (LineInfo.find(Filename) == LineInfo.end()) {
- OwningPtr<MemoryBuffer> Buff;
- if (error_code ec = MemoryBuffer::getFileOrSTDIN(Filename, Buff)) {
- errs() << Filename << ": " << ec.message() << "\n";
- return;
- }
- StringRef AllLines = Buff.take()->getBuffer();
- LineCounts L(AllLines.count('\n'));
- L[Line-1] = Count;
- LineInfo[Filename] = L;
- return;
- }
- LineCounts &L = LineInfo[Filename];
- L[Line-1] = Count;
-}
-
/// print - Print source files with collected line count information.
void FileInfo::print(StringRef gcnoFile, StringRef gcdaFile) {
for (StringMap<LineCounts>::iterator I = LineInfo.begin(), E = LineInfo.end();
@@ -268,16 +250,22 @@ void FileInfo::print(StringRef gcnoFile, StringRef gcdaFile) {
return;
}
StringRef AllLines = Buff.take()->getBuffer();
- for (unsigned i = 0, e = L.size(); i != e; ++i) {
- if (L[i])
- outs() << format("%9lu:", L[i]);
- else
+ uint32_t i = 0;
+ while (!AllLines.empty()) {
+ if (L.find(i) != L.end()) {
+ if (L[i] == 0)
+ outs() << " #####:";
+ else
+ outs() << format("%9lu:", L[i]);
+ } else {
outs() << " -:";
+ }
std::pair<StringRef, StringRef> P = AllLines.split('\n');
if (AllLines != P.first)
outs() << format("%5u:", i+1) << P.first;
outs() << "\n";
AllLines = P.second;
+ ++i;
}
}
}