diff options
author | Douglas Gregor <dgregor@apple.com> | 2010-03-30 18:56:13 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2010-03-30 18:56:13 +0000 |
commit | ad2c6988a28e5e506c29980c785a167c9b0f3294 (patch) | |
tree | 5121f81f9a5a8de34b35a53d2bd35e501b07e4d6 /clang/lib/AST/DeclBase.cpp | |
parent | 6ad816771420611d9947376dbade070e856fb929 (diff) | |
download | bcm5719-llvm-ad2c6988a28e5e506c29980c785a167c9b0f3294.tar.gz bcm5719-llvm-ad2c6988a28e5e506c29980c785a167c9b0f3294.zip |
Introduce new AST statistics that keep track of the number of isa (or
dyn_cast) invocations for C++ and Objective-C types, declarations,
expressions, and statements. The statistics will be printed when
-print-stats is provided to Clang -cc1, with results such as:
277073 clang - Number of checks for C++ declaration nodes
13311 clang - Number of checks for C++ expression nodes
18 clang - Number of checks for C++ statement nodes
174182 clang - Number of checks for C++ type nodes
92300 clang - Number of checks for Objective-C declaration nodes
9800 clang - Number of checks for Objective-C expression nodes
7 clang - Number of checks for Objective-C statement nodes
65733 clang - Number of checks for Objective-C type nodes
The statistics are only gathered when NDEBUG is not defined, since
they introduce potentially-expensive operations into very low-level
routines (isa).
llvm-svn: 99912
Diffstat (limited to 'clang/lib/AST/DeclBase.cpp')
-rw-r--r-- | clang/lib/AST/DeclBase.cpp | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/clang/lib/AST/DeclBase.cpp b/clang/lib/AST/DeclBase.cpp index c693e153dda..522875f64f2 100644 --- a/clang/lib/AST/DeclBase.cpp +++ b/clang/lib/AST/DeclBase.cpp @@ -35,6 +35,13 @@ using namespace clang; // Statistics //===----------------------------------------------------------------------===// +#ifndef NDEBUG +llvm::Statistic clang::objc_decl_checks = + { "clang", "Number of checks for Objective-C declaration nodes", 0, 0 }; +llvm::Statistic clang::cxx_decl_checks = + { "clang", "Number of checks for C++ declaration nodes", 0, 0 }; +#endif + #define DECL(Derived, Base) static int n##Derived##s = 0; #include "clang/AST/DeclNodes.def" |