/ Hex Artifact Content
Login

Artifact 82a433bb1b410714acd84c1c12bfb6d20e1e8ed9e37bd5bb2c7e5026ff092d11:


0000: 23 21 2f 62 69 6e 2f 73 68 0a 23 20 5c 0a 65 78  #!/bin/sh.# \.ex
0010: 65 63 20 74 63 6c 73 68 20 20 22 24 30 22 20 24  ec tclsh  "$0" $
0020: 7b 31 2b 22 24 40 22 7d 0a 23 20 41 20 77 72 61  {1+"$@"}.# A wra
0030: 70 70 65 72 20 61 72 6f 75 6e 64 20 63 67 5f 61  pper around cg_a
0040: 6e 6e 6f 74 61 74 65 20 74 68 61 74 20 73 65 74  nnotate that set
0050: 73 20 61 70 70 72 6f 70 72 69 61 74 65 20 63 6f  s appropriate co
0060: 6d 6d 61 6e 64 2d 6c 69 6e 65 20 6f 70 74 69 6f  mmand-line optio
0070: 6e 73 0a 23 20 61 6e 64 20 72 65 61 72 72 61 6e  ns.# and rearran
0080: 67 65 73 20 74 68 65 20 6f 75 74 70 75 74 20 73  ges the output s
0090: 6f 20 74 68 61 74 20 61 6e 6e 6f 74 61 74 65 64  o that annotated
00a0: 20 66 69 6c 65 73 20 6f 63 63 75 72 20 69 6e 20   files occur in 
00b0: 61 20 63 6f 6e 73 69 73 74 65 6e 74 0a 23 20 73  a consistent.# s
00c0: 6f 72 74 65 64 20 6f 72 64 65 72 2e 20 20 55 73  orted order.  Us
00d0: 65 64 20 62 79 20 74 68 65 20 73 70 65 65 64 2d  ed by the speed-
00e0: 63 68 65 63 6b 2e 74 63 6c 20 73 63 72 69 70 74  check.tcl script
00f0: 2e 0a 23 0a 0a 73 65 74 20 69 6e 20 5b 6f 70 65  ..#..set in [ope
0100: 6e 20 22 7c 63 67 5f 61 6e 6e 6f 74 61 74 65 20  n "|cg_annotate 
0110: 2d 2d 73 68 6f 77 3d 49 72 20 2d 2d 61 75 74 6f  --show=Ir --auto
0120: 3d 79 65 73 20 2d 2d 63 6f 6e 74 65 78 74 3d 34  =yes --context=4
0130: 30 20 24 61 72 67 76 22 20 72 5d 0a 73 65 74 20  0 $argv" r].set 
0140: 64 65 73 74 20 21 0a 73 65 74 20 6f 75 74 28 21  dest !.set out(!
0150: 29 20 7b 7d 0a 73 65 74 20 6c 69 6e 65 6e 75 6d  ) {}.set linenum
0160: 20 30 0a 73 65 74 20 63 6e 74 6c 69 6e 65 73 20   0.set cntlines 
0170: 30 20 20 20 20 20 20 3b 23 20 74 72 75 65 20 74  0      ;# true t
0180: 6f 20 72 65 6d 65 6d 62 65 72 20 63 79 63 6c 65  o remember cycle
0190: 20 63 6f 75 6e 74 73 20 6f 6e 20 65 61 63 68 20   counts on each 
01a0: 6c 69 6e 65 0a 73 65 74 20 73 65 65 6e 53 71 6c  line.set seenSql
01b0: 69 74 65 33 20 30 20 20 20 3b 23 20 74 72 75 65  ite3 0   ;# true
01c0: 20 69 66 20 77 65 20 68 61 76 65 20 73 65 65 6e   if we have seen
01d0: 20 74 68 65 20 73 71 6c 69 74 65 33 2e 63 20 66   the sqlite3.c f
01e0: 69 6c 65 0a 77 68 69 6c 65 20 7b 21 5b 65 6f 66  ile.while {![eof
01f0: 20 24 69 6e 5d 7d 20 7b 0a 20 20 73 65 74 20 6c   $in]} {.  set l
0200: 69 6e 65 20 5b 73 74 72 69 6e 67 20 6d 61 70 20  ine [string map 
0210: 7b 5c 74 20 7b 20 20 20 20 20 20 20 20 7d 7d 20  {\t {        }} 
0220: 5b 67 65 74 73 20 24 69 6e 5d 5d 0a 20 20 69 66  [gets $in]].  if
0230: 20 7b 5b 72 65 67 65 78 70 20 7b 5e 2d 2d 20 41   {[regexp {^-- A
0240: 75 74 6f 2d 61 6e 6e 6f 74 61 74 65 64 20 73 6f  uto-annotated so
0250: 75 72 63 65 3a 20 28 2e 2a 29 7d 20 24 6c 69 6e  urce: (.*)} $lin
0260: 65 20 61 6c 6c 20 6e 61 6d 65 5d 7d 20 7b 0a 20  e all name]} {. 
0270: 20 20 20 73 65 74 20 64 65 73 74 20 24 6e 61 6d     set dest $nam
0280: 65 0a 20 20 20 20 69 66 20 7b 5b 73 74 72 69 6e  e.    if {[strin
0290: 67 20 6d 61 74 63 68 20 2a 2f 73 71 6c 69 74 65  g match */sqlite
02a0: 33 2e 63 20 24 64 65 73 74 5d 7d 20 7b 0a 20 20  3.c $dest]} {.  
02b0: 20 20 20 20 73 65 74 20 63 6e 74 6c 69 6e 65 73      set cntlines
02c0: 20 31 0a 20 20 20 20 20 20 73 65 74 20 73 65 65   1.      set see
02d0: 6e 53 71 6c 69 74 65 33 20 31 0a 20 20 20 20 7d  nSqlite3 1.    }
02e0: 20 65 6c 73 65 20 7b 0a 20 20 20 20 20 20 73 65   else {.      se
02f0: 74 20 63 6e 74 6c 69 6e 65 73 20 30 0a 20 20 20  t cntlines 0.   
0300: 20 7d 0a 20 20 7d 20 65 6c 73 65 69 66 20 7b 5b   }.  } elseif {[
0310: 72 65 67 65 78 70 20 7b 5e 2d 2d 20 6c 69 6e 65  regexp {^-- line
0320: 20 28 5c 64 2b 29 20 2d 2d 2d 2d 2d 2d 7d 20 24   (\d+) ------} $
0330: 6c 69 6e 65 20 61 6c 6c 20 6c 6e 5d 7d 20 7b 0a  line all ln]} {.
0340: 20 20 20 20 73 65 74 20 6c 69 6e 65 20 5b 6c 72      set line [lr
0350: 65 70 6c 61 63 65 20 24 6c 69 6e 65 20 32 20 32  eplace $line 2 2
0360: 20 7b 23 7d 5d 0a 20 20 20 20 73 65 74 20 6c 69   {#}].    set li
0370: 6e 65 6e 75 6d 20 5b 65 78 70 72 20 7b 24 6c 6e  nenum [expr {$ln
0380: 2d 31 7d 5d 0a 20 20 7d 20 65 6c 73 65 69 66 20  -1}].  } elseif 
0390: 7b 5b 72 65 67 65 78 70 20 7b 5e 54 68 65 20 66  {[regexp {^The f
03a0: 6f 6c 6c 6f 77 69 6e 67 20 66 69 6c 65 73 20 63  ollowing files c
03b0: 68 6f 73 65 6e 20 66 6f 72 20 7d 20 24 6c 69 6e  hosen for } $lin
03c0: 65 5d 7d 20 7b 0a 20 20 20 20 73 65 74 20 64 65  e]} {.    set de
03d0: 73 74 20 21 0a 20 20 7d 0a 20 20 61 70 70 65 6e  st !.  }.  appen
03e0: 64 20 6f 75 74 28 24 64 65 73 74 29 20 24 6c 69  d out($dest) $li
03f0: 6e 65 5c 6e 0a 20 20 69 66 20 7b 24 63 6e 74 6c  ne\n.  if {$cntl
0400: 69 6e 65 73 7d 20 7b 0a 20 20 20 20 69 6e 63 72  ines} {.    incr
0410: 20 6c 69 6e 65 6e 75 6d 0a 20 20 20 20 69 66 20   linenum.    if 
0420: 7b 5b 72 65 67 65 78 70 20 7b 5e 20 2a 28 5b 30  {[regexp {^ *([0
0430: 2d 39 2c 5d 2b 29 20 7d 20 24 6c 69 6e 65 20 61  -9,]+) } $line a
0440: 6c 6c 20 78 5d 7d 20 7b 0a 20 20 20 20 20 20 73  ll x]} {.      s
0450: 65 74 20 78 20 5b 73 74 72 69 6e 67 20 6d 61 70  et x [string map
0460: 20 7b 2c 20 7b 7d 7d 20 24 78 5d 0a 20 20 20 20   {, {}} $x].    
0470: 20 20 73 65 74 20 63 79 63 6c 65 73 28 24 6c 69    set cycles($li
0480: 6e 65 6e 75 6d 29 20 24 78 0a 20 20 20 20 7d 0a  nenum) $x.    }.
0490: 20 20 7d 0a 7d 0a 66 6f 72 65 61 63 68 20 78 20    }.}.foreach x 
04a0: 5b 6c 73 6f 72 74 20 5b 61 72 72 61 79 20 6e 61  [lsort [array na
04b0: 6d 65 73 20 6f 75 74 5d 5d 20 7b 0a 20 20 70 75  mes out]] {.  pu
04c0: 74 73 20 24 6f 75 74 28 24 78 29 0a 7d 0a 0a 23  ts $out($x).}..#
04d0: 20 49 66 20 74 68 65 20 73 71 6c 69 74 65 33 2e   If the sqlite3.
04e0: 63 20 66 69 6c 65 20 68 61 73 20 62 65 65 6e 20  c file has been 
04f0: 73 65 65 6e 2c 20 74 68 65 6e 20 6f 75 74 70 75  seen, then outpu
0500: 74 20 61 20 73 75 6d 6d 61 72 79 20 6f 66 20 74  t a summary of t
0510: 68 65 0a 23 20 63 79 63 6c 65 20 63 6f 75 6e 74  he.# cycle count
0520: 73 20 66 6f 72 20 65 61 63 68 20 66 69 6c 65 20  s for each file 
0530: 74 68 61 74 20 77 65 6e 74 20 69 6e 74 6f 20 6d  that went into m
0540: 61 6b 69 6e 67 20 75 70 20 73 71 6c 69 74 65 33  aking up sqlite3
0550: 2e 63 0a 23 0a 69 66 20 7b 24 73 65 65 6e 53 71  .c.#.if {$seenSq
0560: 6c 69 74 65 33 7d 20 7b 0a 20 20 63 6c 6f 73 65  lite3} {.  close
0570: 20 24 69 6e 0a 20 20 73 65 74 20 69 6e 20 5b 6f   $in.  set in [o
0580: 70 65 6e 20 73 71 6c 69 74 65 33 2e 63 5d 0a 20  pen sqlite3.c]. 
0590: 20 73 65 74 20 6c 69 6e 65 6e 75 6d 20 30 0a 20   set linenum 0. 
05a0: 20 73 65 74 20 66 6e 20 73 71 6c 69 74 65 33 2e   set fn sqlite3.
05b0: 63 0a 20 20 73 65 74 20 70 61 74 74 65 72 6e 31  c.  set pattern1
05c0: 20 7b 5e 2f 5c 2a 2b 20 42 65 67 69 6e 20 66 69   {^/\*+ Begin fi
05d0: 6c 65 20 28 5b 5e 20 5d 2b 29 20 5c 2a 7d 0a 20  le ([^ ]+) \*}. 
05e0: 20 73 65 74 20 70 61 74 74 65 72 6e 32 20 7b 5e   set pattern2 {^
05f0: 2f 5c 2a 2b 20 43 6f 6e 74 69 6e 75 69 6e 67 20  /\*+ Continuing 
0600: 77 68 65 72 65 20 77 65 20 6c 65 66 74 20 6f 66  where we left of
0610: 66 20 69 6e 20 28 5b 5e 20 5d 2b 29 20 5c 2a 7d  f in ([^ ]+) \*}
0620: 0a 20 20 77 68 69 6c 65 20 7b 21 5b 65 6f 66 20  .  while {![eof 
0630: 24 69 6e 5d 7d 20 7b 0a 20 20 20 20 73 65 74 20  $in]} {.    set 
0640: 6c 69 6e 65 20 5b 67 65 74 73 20 24 69 6e 5d 0a  line [gets $in].
0650: 20 20 20 20 69 6e 63 72 20 6c 69 6e 65 6e 75 6d      incr linenum
0660: 0a 20 20 20 20 69 66 20 7b 5b 72 65 67 65 78 70  .    if {[regexp
0670: 20 24 70 61 74 74 65 72 6e 31 20 24 6c 69 6e 65   $pattern1 $line
0680: 20 61 6c 6c 20 6e 65 77 66 6e 5d 7d 20 7b 0a 20   all newfn]} {. 
0690: 20 20 20 20 20 73 65 74 20 66 6e 20 24 6e 65 77       set fn $new
06a0: 66 6e 0a 20 20 20 20 7d 20 65 6c 73 65 69 66 20  fn.    } elseif 
06b0: 7b 5b 72 65 67 65 78 70 20 24 70 61 74 74 65 72  {[regexp $patter
06c0: 6e 32 20 24 6c 69 6e 65 20 61 6c 6c 20 6e 65 77  n2 $line all new
06d0: 66 6e 5d 7d 20 7b 0a 20 20 20 20 20 20 73 65 74  fn]} {.      set
06e0: 20 66 6e 20 24 6e 65 77 66 6e 0a 20 20 20 20 7d   fn $newfn.    }
06f0: 20 65 6c 73 65 69 66 20 7b 5b 69 6e 66 6f 20 65   elseif {[info e
0700: 78 69 73 74 73 20 63 79 63 6c 65 73 28 24 6c 69  xists cycles($li
0710: 6e 65 6e 75 6d 29 5d 7d 20 7b 0a 20 20 20 20 20  nenum)]} {.     
0720: 20 69 6e 63 72 20 66 63 79 63 6c 65 73 28 24 66   incr fcycles($f
0730: 6e 29 20 24 63 79 63 6c 65 73 28 24 6c 69 6e 65  n) $cycles($line
0740: 6e 75 6d 29 0a 20 20 20 20 7d 0a 20 20 7d 0a 20  num).    }.  }. 
0750: 20 63 6c 6f 73 65 20 24 69 6e 0a 20 20 70 75 74   close $in.  put
0760: 73 20 7b 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  s {*************
0770: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0780: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0790: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
07a0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 7d 0a 20 20 73 65 74  *********}.  set
07b0: 20 6c 78 20 7b 7d 0a 20 20 73 65 74 20 73 75 6d   lx {}.  set sum
07c0: 20 30 0a 20 20 66 6f 72 65 61 63 68 20 7b 66 6e   0.  foreach {fn
07d0: 20 63 6e 74 7d 20 5b 61 72 72 61 79 20 67 65 74   cnt} [array get
07e0: 20 66 63 79 63 6c 65 73 5d 20 7b 0a 20 20 20 20   fcycles] {.    
07f0: 6c 61 70 70 65 6e 64 20 6c 78 20 5b 6c 69 73 74  lappend lx [list
0800: 20 24 63 6e 74 20 24 66 6e 5d 0a 20 20 20 20 69   $cnt $fn].    i
0810: 6e 63 72 20 73 75 6d 20 24 63 6e 74 0a 20 20 7d  ncr sum $cnt.  }
0820: 0a 20 20 70 75 74 73 20 5b 66 6f 72 6d 61 74 20  .  puts [format 
0830: 7b 25 32 30 73 20 25 31 34 64 20 20 25 38 2e 33  {%20s %14d  %8.3
0840: 66 25 25 7d 20 54 4f 54 41 4c 20 24 73 75 6d 20  f%%} TOTAL $sum 
0850: 31 30 30 5d 0a 20 20 66 6f 72 65 61 63 68 20 65  100].  foreach e
0860: 6e 74 72 79 20 5b 6c 73 6f 72 74 20 2d 69 6e 64  ntry [lsort -ind
0870: 65 78 20 30 20 2d 69 6e 74 65 67 65 72 20 2d 64  ex 0 -integer -d
0880: 65 63 72 65 61 73 69 6e 67 20 24 6c 78 5d 20 7b  ecreasing $lx] {
0890: 0a 20 20 20 20 66 6f 72 65 61 63 68 20 7b 63 6e  .    foreach {cn
08a0: 74 20 66 6e 7d 20 24 65 6e 74 72 79 20 62 72 65  t fn} $entry bre
08b0: 61 6b 0a 20 20 20 20 70 75 74 73 20 5b 66 6f 72  ak.    puts [for
08c0: 6d 61 74 20 7b 25 32 30 73 20 25 31 34 64 20 20  mat {%20s %14d  
08d0: 25 38 2e 33 66 25 25 7d 20 24 66 6e 20 24 63 6e  %8.3f%%} $fn $cn
08e0: 74 20 5b 65 78 70 72 20 7b 24 63 6e 74 2a 31 30  t [expr {$cnt*10
08f0: 30 2e 30 2f 24 73 75 6d 7d 5d 5d 0a 20 20 7d 0a  0.0/$sum}]].  }.
0900: 7d 0a                                            }.