diff options
author | Douglas Gregor <dgregor@apple.com> | 2009-04-17 22:13:46 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2009-04-17 22:13:46 +0000 |
commit | 08f012900320664f6bc41082cc0e14460b35422f (patch) | |
tree | 87abb541b423046461619dda86567f89bf52a773 /clang/lib/Frontend/PCHReader.cpp | |
parent | 6fdd57cba86bdfeae99987b001f965f69d0e6704 (diff) | |
download | bcm5719-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.cpp | 12 |
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) { |