| #!/usr/bin/env python |
| |
| """ |
| Script to Summarize statistics in the scan-build output. |
| |
| Statistics are enabled by passing '-internal-stats' option to scan-build |
| (or '-analyzer-stats' to the analyzer). |
| |
| """ |
| |
| import string |
| from operator import itemgetter |
| import sys |
| |
| if __name__ == '__main__': |
| if len(sys.argv) < 2: |
| print >> sys.stderr, 'Usage: ', sys.argv[0],\ |
| 'scan_build_output_file' |
| sys.exit(-1) |
| |
| f = open(sys.argv[1], 'r') |
| Time = 0.0 |
| TotalTime = 0.0 |
| MaxTime = 0.0 |
| Warnings = 0 |
| Count = 0 |
| FunctionsAnalyzed = 0 |
| ReachableBlocks = 0 |
| ReachedMaxSteps = 0 |
| NumSteps = 0 |
| NumInlinedCallSites = 0 |
| NumBifurcatedCallSites = 0 |
| MaxCFGSize = 0 |
| Mode = 1 |
| for line in f: |
| if ("Miscellaneous Ungrouped Timers" in line) : |
| Mode = 1 |
| if (("Analyzer Total Time" in line) and (Mode == 1)) : |
| s = line.split() |
| Time = Time + float(s[6]) |
| Count = Count + 1 |
| if (float(s[6]) > MaxTime) : |
| MaxTime = float(s[6]) |
| if ((("warning generated." in line) or ("warnings generated" in line)) and Mode == 1) : |
| s = line.split() |
| Warnings = Warnings + int(s[0]) |
| if (("The # of functions analysed (as top level)" in line) and (Mode == 1)) : |
| s = line.split() |
| FunctionsAnalyzed = FunctionsAnalyzed + int(s[0]) |
| if (("The % of reachable basic blocks" in line) and (Mode == 1)) : |
| s = line.split() |
| ReachableBlocks = ReachableBlocks + int(s[0]) |
| if (("The # of times we reached the max number of steps" in line) and (Mode == 1)) : |
| s = line.split() |
| ReachedMaxSteps = ReachedMaxSteps + int(s[0]) |
| if (("The maximum number of basic blocks in a function" in line) and (Mode == 1)) : |
| s = line.split() |
| if (MaxCFGSize < int(s[0])) : |
| MaxCFGSize = int(s[0]) |
| if (("The # of steps executed" in line) and (Mode == 1)) : |
| s = line.split() |
| NumSteps = NumSteps + int(s[0]) |
| if (("The # of times we inlined a call" in line) and (Mode == 1)) : |
| s = line.split() |
| NumInlinedCallSites = NumInlinedCallSites + int(s[0]) |
| if (("The # of times we split the path due to imprecise dynamic dispatch info" in line) and (Mode == 1)) : |
| s = line.split() |
| NumBifurcatedCallSites = NumBifurcatedCallSites + int(s[0]) |
| if ((") Total" in line) and (Mode == 1)) : |
| s = line.split() |
| TotalTime = TotalTime + float(s[6]) |
| |
| print "TU Count %d" % (Count) |
| print "Time %f" % (Time) |
| print "Warnings %d" % (Warnings) |
| print "Functions Analyzed %d" % (FunctionsAnalyzed) |
| print "Reachable Blocks %d" % (ReachableBlocks) |
| print "Reached Max Steps %d" % (ReachedMaxSteps) |
| print "Number of Steps %d" % (NumSteps) |
| print "Number of Inlined calls %d (bifurcated %d)" % (NumInlinedCallSites, NumBifurcatedCallSites) |
| print "MaxTime %f" % (MaxTime) |
| print "TotalTime %f" % (TotalTime) |
| print "Max CFG Size %d" % (MaxCFGSize) |
| |