summaryrefslogtreecommitdiffstats
path: root/clang/lib/Frontend/PCHReader.cpp
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2009-04-17 22:13:46 +0000
committerDouglas Gregor <dgregor@apple.com>2009-04-17 22:13:46 +0000
commit08f012900320664f6bc41082cc0e14460b35422f (patch)
tree87abb541b423046461619dda86567f89bf52a773 /clang/lib/Frontend/PCHReader.cpp
parent6fdd57cba86bdfeae99987b001f965f69d0e6704 (diff)
downloadbcm5719-llvm-08f012900320664f6bc41082cc0e14460b35422f.tar.gz
bcm5719-llvm-08f012900320664f6bc41082cc0e14460b35422f.zip
Keep track of the number of statements/expressions written to and read
from a PCH file. It turns out that "Hello, World!" is bringing in 19% of all of the statements in Carbon.h, so we need to be lazy. llvm-svn: 69393
Diffstat (limited to 'clang/lib/Frontend/PCHReader.cpp')
-rw-r--r--clang/lib/Frontend/PCHReader.cpp12
1 files changed, 11 insertions, 1 deletions
diff --git a/clang/lib/Frontend/PCHReader.cpp b/clang/lib/Frontend/PCHReader.cpp
index da7b4229aa1..5ea1f7c6c22 100644
--- a/clang/lib/Frontend/PCHReader.cpp
+++ b/clang/lib/Frontend/PCHReader.cpp
@@ -1173,7 +1173,7 @@ PCHReader::PCHReadResult PCHReader::ReadPCHBlock() {
}
uint64_t PreprocessorBlockBit = 0;
-
+
// Read all of the records and blocks for the PCH file.
RecordData Record;
while (!Stream.AtEndOfStream()) {
@@ -1315,6 +1315,11 @@ PCHReader::PCHReadResult PCHReader::ReadPCHBlock() {
}
ExternalDefinitions.swap(Record);
break;
+
+ case pch::STATISTICS:
+ TotalNumStatements = Record[0];
+ break;
+
}
}
@@ -1976,6 +1981,9 @@ void PCHReader::PrintStats() {
std::fprintf(stderr, " %u/%u identifiers read (%f%%)\n",
NumIdentifiersLoaded, (unsigned)IdentifierData.size(),
((float)NumIdentifiersLoaded/IdentifierData.size() * 100));
+ std::fprintf(stderr, " %u/%u statements read (%f%%)\n",
+ NumStatementsRead, TotalNumStatements,
+ ((float)NumStatementsRead/TotalNumStatements * 100));
std::fprintf(stderr, "\n");
}
@@ -2450,6 +2458,8 @@ Stmt *PCHReader::ReadStmt() {
if (Finished)
break;
+ ++NumStatementsRead;
+
if (S) {
unsigned NumSubStmts = Reader.Visit(S);
while (NumSubStmts > 0) {
OpenPOWER on IntegriCloud