3.7. Analysis Statistics

Clang Static Analyzer enjoys two facilities to collect statistics: per translation unit and per entry point. We use llvm/ADT/Statistic.h for numbers describing the entire translation unit. We use clang/StaticAnalyzer/Core/PathSensitive/EntryPointStats.h to collect data for each symbolic-execution entry point.

In many cases, it makes sense to collect statistics on both translation-unit level and entry-point level. You can use the two macros defined in EntryPointStats.h for that:

If you want to define a statistic that makes sense only for the entire translation unit, for example, “the number of entry points”, Statistic.h defines two macros: STATISTIC and ALWAYS_ENABLED_STATISTIC. You should prefer ALWAYS_ENABLED_STATISTIC unless you have a good reason not to. STATISTIC is controlled by LLVM_ENABLE_STATS / LLVM_FORCE_ENABLE_STATS. However, note that with LLVM_ENABLE_STATS disabled, only storage of the values is disabled, the computations producing those values still carry on unless you took an explicit precaution to make them conditional too.

If you want to define a statistic only for entry point, EntryPointStats.h has four classes at your disposal:

To produce a CSV file with all the statistics collected per entry point, use the dump-entry-point-stats-to-csv=<file>.csv parameter.

Note, EntryPointStats.h is not meant to be complete, and if you feel it is lacking certain kind of statistic, odds are that it does. Feel free to extend it!