Megatest

Hex Artifact Content
Login

Artifact e9212eda7d2fcf5ab8e3125e839561b8b28b7187:


0000: 3b 3b 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ;;==============
0010: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0020: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0030: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0040: 3d 3d 3d 3d 3d 3d 3d 3d 0a 3b 3b 20 43 6f 70 79  ========.;; Copy
0050: 72 69 67 68 74 20 32 30 30 36 2d 32 30 31 31 2c  right 2006-2011,
0060: 20 4d 61 74 74 68 65 77 20 57 65 6c 6c 61 6e 64   Matthew Welland
0070: 2e 0a 3b 3b 20 0a 3b 3b 20 20 54 68 69 73 20 70  ..;; .;;  This p
0080: 72 6f 67 72 61 6d 20 69 73 20 6d 61 64 65 20 61  rogram is made a
0090: 76 61 69 6c 61 62 6c 65 20 75 6e 64 65 72 20 74  vailable under t
00a0: 68 65 20 47 4e 55 20 47 50 4c 20 76 65 72 73 69  he GNU GPL versi
00b0: 6f 6e 20 32 2e 30 20 6f 72 0a 3b 3b 20 20 67 72  on 2.0 or.;;  gr
00c0: 65 61 74 65 72 2e 20 53 65 65 20 74 68 65 20 61  eater. See the a
00d0: 63 63 6f 6d 70 61 6e 79 69 6e 67 20 66 69 6c 65  ccompanying file
00e0: 20 43 4f 50 59 49 4e 47 20 66 6f 72 20 64 65 74   COPYING for det
00f0: 61 69 6c 73 2e 0a 3b 3b 20 0a 3b 3b 20 20 54 68  ails..;; .;;  Th
0100: 69 73 20 70 72 6f 67 72 61 6d 20 69 73 20 64 69  is program is di
0110: 73 74 72 69 62 75 74 65 64 20 57 49 54 48 4f 55  stributed WITHOU
0120: 54 20 41 4e 59 20 57 41 52 52 41 4e 54 59 3b 20  T ANY WARRANTY; 
0130: 77 69 74 68 6f 75 74 20 65 76 65 6e 20 74 68 65  without even the
0140: 0a 3b 3b 20 20 69 6d 70 6c 69 65 64 20 77 61 72  .;;  implied war
0150: 72 61 6e 74 79 20 6f 66 20 4d 45 52 43 48 41 4e  ranty of MERCHAN
0160: 54 41 42 49 4c 49 54 59 20 6f 72 20 46 49 54 4e  TABILITY or FITN
0170: 45 53 53 20 46 4f 52 20 41 20 50 41 52 54 49 43  ESS FOR A PARTIC
0180: 55 4c 41 52 0a 3b 3b 20 20 50 55 52 50 4f 53 45  ULAR.;;  PURPOSE
0190: 2e 0a 3b 3b 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ..;;============
01a0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
01b0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
01c0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
01d0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 0a 0a 28 75 73 65  ==========..(use
01e0: 20 66 6f 72 6d 61 74 29 0a 28 72 65 71 75 69 72   format).(requir
01f0: 65 2d 6c 69 62 72 61 72 79 20 69 75 70 29 0a 28  e-library iup).(
0200: 69 6d 70 6f 72 74 20 28 70 72 65 66 69 78 20 69  import (prefix i
0210: 75 70 20 69 75 70 3a 29 29 0a 0a 28 75 73 65 20  up iup:))..(use 
0220: 63 61 6e 76 61 73 2d 64 72 61 77 29 0a 0a 28 75  canvas-draw)..(u
0230: 73 65 20 73 71 6c 69 74 65 33 20 73 72 66 69 2d  se sqlite3 srfi-
0240: 31 20 70 6f 73 69 78 20 72 65 67 65 78 20 72 65  1 posix regex re
0250: 67 65 78 2d 63 61 73 65 20 73 72 66 69 2d 36 39  gex-case srfi-69
0260: 29 0a 0a 28 69 6d 70 6f 72 74 20 28 70 72 65 66  )..(import (pref
0270: 69 78 20 73 71 6c 69 74 65 33 20 73 71 6c 69 74  ix sqlite3 sqlit
0280: 65 33 3a 29 29 0a 0a 28 69 6e 63 6c 75 64 65 20  e3:))..(include 
0290: 22 63 6f 6d 6d 6f 6e 2e 73 63 6d 22 29 0a 28 69  "common.scm").(i
02a0: 6e 63 6c 75 64 65 20 22 6d 61 72 67 73 2e 73 63  nclude "margs.sc
02b0: 6d 22 29 0a 28 69 6e 63 6c 75 64 65 20 22 6b 65  m").(include "ke
02c0: 79 73 2e 73 63 6d 22 29 0a 28 69 6e 63 6c 75 64  ys.scm").(includ
02d0: 65 20 22 69 74 65 6d 73 2e 73 63 6d 22 29 0a 28  e "items.scm").(
02e0: 69 6e 63 6c 75 64 65 20 22 64 62 2e 73 63 6d 22  include "db.scm"
02f0: 29 0a 28 69 6e 63 6c 75 64 65 20 22 63 6f 6e 66  ).(include "conf
0300: 69 67 66 2e 73 63 6d 22 29 0a 28 69 6e 63 6c 75  igf.scm").(inclu
0310: 64 65 20 22 70 72 6f 63 65 73 73 2e 73 63 6d 22  de "process.scm"
0320: 29 0a 28 69 6e 63 6c 75 64 65 20 22 6c 61 75 6e  ).(include "laun
0330: 63 68 2e 73 63 6d 22 29 0a 28 69 6e 63 6c 75 64  ch.scm").(includ
0340: 65 20 22 72 75 6e 73 2e 73 63 6d 22 29 0a 28 69  e "runs.scm").(i
0350: 6e 63 6c 75 64 65 20 22 67 75 69 2e 73 63 6d 22  nclude "gui.scm"
0360: 29 0a 28 69 6e 63 6c 75 64 65 20 22 64 61 73 68  ).(include "dash
0370: 62 6f 61 72 64 2d 74 65 73 74 73 2e 73 63 6d 22  board-tests.scm"
0380: 29 0a 0a 28 64 65 66 69 6e 65 20 68 65 6c 70 20  )..(define help 
0390: 22 0a 4d 65 67 61 74 65 73 74 20 44 61 73 68 62  ".Megatest Dashb
03a0: 6f 61 72 64 2c 20 64 6f 63 75 6d 65 6e 74 61 74  oard, documentat
03b0: 69 6f 6e 20 61 74 20 68 74 74 70 3a 2f 2f 77 77  ion at http://ww
03c0: 77 2e 6b 69 61 74 6f 61 2e 63 6f 6d 2f 66 6f 73  w.kiatoa.com/fos
03d0: 73 69 6c 73 2f 6d 65 67 61 74 65 73 74 0a 20 20  sils/megatest.  
03e0: 76 65 72 73 69 6f 6e 20 30 2e 32 0a 20 20 6c 69  version 0.2.  li
03f0: 63 65 6e 73 65 20 47 50 4c 2c 20 43 6f 70 79 72  cense GPL, Copyr
0400: 69 67 68 74 20 4d 61 74 74 20 57 65 6c 6c 61 6e  ight Matt Wellan
0410: 64 20 32 30 31 31 0a 0a 55 73 61 67 65 3a 20 64  d 2011..Usage: d
0420: 61 73 68 62 6f 61 72 64 20 5b 6f 70 74 69 6f 6e  ashboard [option
0430: 73 5d 0a 20 20 2d 68 20 20 20 20 20 20 20 20 20  s].  -h         
0440: 20 20 20 20 20 3a 20 74 68 69 73 20 68 65 6c 70       : this help
0450: 0a 20 20 2d 72 75 6e 20 72 75 6e 69 64 20 20 20  .  -run runid   
0460: 20 20 20 3a 20 63 6f 6e 74 72 6f 6c 20 72 75 6e     : control run
0470: 20 69 64 65 6e 74 69 66 69 65 64 20 62 79 20 72   identified by r
0480: 75 6e 69 64 0a 20 20 2d 74 65 73 74 20 74 65 73  unid.  -test tes
0490: 74 69 64 20 20 20 20 3a 20 63 6f 6e 74 72 6f 6c  tid    : control
04a0: 20 74 65 73 74 20 69 64 65 6e 74 69 66 69 65 64   test identified
04b0: 20 62 79 20 74 65 73 74 69 64 0a 0a 4d 69 73 63   by testid..Misc
04c0: 0a 20 20 2d 72 6f 77 73 20 4e 20 20 20 20 20 20  .  -rows N      
04d0: 20 20 20 3a 20 73 65 74 20 6e 75 6d 62 65 72 20     : set number 
04e0: 6f 66 20 72 6f 77 73 0a 22 29 0a 0a 3b 3b 20 70  of rows.")..;; p
04f0: 72 6f 63 65 73 73 20 61 72 67 73 0a 28 64 65 66  rocess args.(def
0500: 69 6e 65 20 72 65 6d 61 72 67 73 20 28 61 72 67  ine remargs (arg
0510: 73 3a 67 65 74 2d 61 72 67 73 20 0a 09 09 20 28  s:get-args ... (
0520: 61 72 67 76 29 0a 09 09 20 28 6c 69 73 74 20 20  argv)... (list  
0530: 22 2d 72 6f 77 73 22 0a 09 09 09 22 2d 72 75 6e  "-rows"...."-run
0540: 22 0a 09 09 09 22 2d 74 65 73 74 22 0a 09 09 09  "...."-test"....
0550: 22 2d 64 65 62 75 67 22 0a 09 09 09 29 20 0a 09  "-debug"....) ..
0560: 09 20 28 6c 69 73 74 20 20 22 2d 68 22 0a 09 09  . (list  "-h"...
0570: 09 22 2d 76 22 0a 09 09 09 22 2d 71 22 0a 09 09  ."-v"...."-q"...
0580: 20 20 20 20 20 20 20 29 0a 09 09 20 61 72 67 73         )... args
0590: 3a 61 72 67 2d 68 61 73 68 0a 09 09 20 30 29 29  :arg-hash... 0))
05a0: 0a 0a 28 69 66 20 28 61 72 67 73 3a 67 65 74 2d  ..(if (args:get-
05b0: 61 72 67 20 22 2d 68 22 29 0a 20 20 20 20 28 62  arg "-h").    (b
05c0: 65 67 69 6e 0a 20 20 20 20 20 20 28 70 72 69 6e  egin.      (prin
05d0: 74 20 68 65 6c 70 29 0a 20 20 20 20 20 20 28 65  t help).      (e
05e0: 78 69 74 29 29 29 0a 0a 28 69 66 20 28 6e 6f 74  xit)))..(if (not
05f0: 20 28 73 65 74 75 70 2d 66 6f 72 2d 72 75 6e 29   (setup-for-run)
0600: 29 0a 20 20 20 20 28 62 65 67 69 6e 0a 20 20 20  ).    (begin.   
0610: 20 20 20 28 70 72 69 6e 74 20 22 46 61 69 6c 65     (print "Faile
0620: 64 20 74 6f 20 66 69 6e 64 20 6d 65 67 61 74 65  d to find megate
0630: 73 74 2e 63 6f 6e 66 69 67 2c 20 65 78 69 74 69  st.config, exiti
0640: 6e 67 22 29 20 0a 20 20 20 20 20 20 28 65 78 69  ng") .      (exi
0650: 74 20 31 29 29 29 0a 0a 28 64 65 66 69 6e 65 20  t 1)))..(define 
0660: 2a 64 62 2a 20 28 6f 70 65 6e 2d 64 62 29 29 0a  *db* (open-db)).
0670: 0a 28 64 65 66 69 6e 65 20 74 6f 70 6c 65 76 65  .(define topleve
0680: 6c 20 23 66 29 0a 28 64 65 66 69 6e 65 20 64 6c  l #f).(define dl
0690: 67 20 20 20 20 20 20 23 66 29 0a 28 64 65 66 69  g      #f).(defi
06a0: 6e 65 20 6d 61 78 2d 74 65 73 74 2d 6e 75 6d 20  ne max-test-num 
06b0: 30 29 0a 28 64 65 66 69 6e 65 20 2a 6b 65 79 73  0).(define *keys
06c0: 2a 20 20 20 28 67 65 74 2d 6b 65 79 73 20 20 20  *   (get-keys   
06d0: 2a 64 62 2a 29 29 0a 28 64 65 66 69 6e 65 20 64  *db*)).(define d
06e0: 62 6b 65 79 73 20 20 20 28 6d 61 70 20 28 6c 61  bkeys   (map (la
06f0: 6d 62 64 61 20 28 78 29 28 76 65 63 74 6f 72 2d  mbda (x)(vector-
0700: 72 65 66 20 78 20 30 29 29 0a 09 09 20 20 20 20  ref x 0))...    
0710: 20 20 28 61 70 70 65 6e 64 20 2a 6b 65 79 73 2a    (append *keys*
0720: 20 28 6c 69 73 74 20 28 76 65 63 74 6f 72 20 22   (list (vector "
0730: 72 75 6e 6e 61 6d 65 22 20 22 62 6c 61 68 22 29  runname" "blah")
0740: 29 29 29 29 0a 28 64 65 66 69 6e 65 20 2a 68 65  )))).(define *he
0750: 61 64 65 72 2a 20 20 20 20 20 20 20 23 66 29 0a  ader*       #f).
0760: 28 64 65 66 69 6e 65 20 2a 61 6c 6c 72 75 6e 73  (define *allruns
0770: 2a 20 20 20 20 20 27 28 29 29 0a 28 64 65 66 69  *     '()).(defi
0780: 6e 65 20 2a 62 75 74 74 6f 6e 64 61 74 2a 20 20  ne *buttondat*  
0790: 20 20 28 6d 61 6b 65 2d 68 61 73 68 2d 74 61 62    (make-hash-tab
07a0: 6c 65 29 29 20 3b 3b 20 3c 72 75 6e 2d 69 64 20  le)) ;; <run-id 
07b0: 63 6f 6c 6f 72 20 74 65 78 74 20 74 65 73 74 20  color text test 
07c0: 72 75 6e 2d 6b 65 79 3e 0a 28 64 65 66 69 6e 65  run-key>.(define
07d0: 20 2a 61 6c 6c 74 65 73 74 6e 61 6d 65 6c 73 74   *alltestnamelst
07e0: 2a 20 27 28 29 29 0a 28 64 65 66 69 6e 65 20 2a  * '()).(define *
07f0: 73 65 61 72 63 68 70 61 74 74 73 2a 20 20 28 6d  searchpatts*  (m
0800: 61 6b 65 2d 68 61 73 68 2d 74 61 62 6c 65 29 29  ake-hash-table))
0810: 0a 28 64 65 66 69 6e 65 20 2a 6e 75 6d 2d 72 75  .(define *num-ru
0820: 6e 73 2a 20 20 20 20 20 20 31 30 29 0a 28 64 65  ns*      10).(de
0830: 66 69 6e 65 20 2a 6e 75 6d 2d 74 65 73 74 73 2a  fine *num-tests*
0840: 20 20 20 20 20 31 35 29 0a 28 64 65 66 69 6e 65       15).(define
0850: 20 2a 73 74 61 72 74 2d 72 75 6e 2d 6f 66 66 73   *start-run-offs
0860: 65 74 2a 20 20 30 29 0a 28 64 65 66 69 6e 65 20  et*  0).(define 
0870: 2a 73 74 61 72 74 2d 74 65 73 74 2d 6f 66 66 73  *start-test-offs
0880: 65 74 2a 20 30 29 0a 28 64 65 66 69 6e 65 20 2a  et* 0).(define *
0890: 65 78 61 6d 69 6e 65 2d 74 65 73 74 2d 64 61 74  examine-test-dat
08a0: 2a 20 28 6d 61 6b 65 2d 68 61 73 68 2d 74 61 62  * (make-hash-tab
08b0: 6c 65 29 29 0a 28 64 65 66 69 6e 65 20 2a 65 78  le)).(define *ex
08c0: 69 74 2d 73 74 61 72 74 65 64 2a 20 23 66 29 0a  it-started* #f).
08d0: 0a 28 64 65 66 69 6e 65 20 2a 76 65 72 62 6f 73  .(define *verbos
08e0: 69 74 79 2a 20 28 63 6f 6e 64 0a 09 09 20 20 20  ity* (cond...   
08f0: 20 20 28 28 61 72 67 73 3a 67 65 74 2d 61 72 67    ((args:get-arg
0900: 20 22 2d 64 65 62 75 67 22 29 28 73 74 72 69 6e   "-debug")(strin
0910: 67 2d 3e 6e 75 6d 62 65 72 20 28 61 72 67 73 3a  g->number (args:
0920: 67 65 74 2d 61 72 67 20 22 2d 64 65 62 75 67 22  get-arg "-debug"
0930: 29 29 29 0a 09 09 20 20 20 20 20 28 28 61 72 67  )))...     ((arg
0940: 73 3a 67 65 74 2d 61 72 67 20 22 2d 76 22 29 20  s:get-arg "-v") 
0950: 20 20 20 32 29 0a 09 09 20 20 20 20 20 28 28 61     2)...     ((a
0960: 72 67 73 3a 67 65 74 2d 61 72 67 20 22 2d 71 22  rgs:get-arg "-q"
0970: 29 20 20 20 20 30 29 0a 09 09 20 20 20 20 20 28  )    0)...     (
0980: 65 6c 73 65 20 20 20 20 20 20 20 20 20 20 20 20  else            
0990: 20 20 20 20 20 20 20 31 29 29 29 0a 0a 28 64 65         1)))..(de
09a0: 66 69 6e 65 20 75 69 64 61 74 20 23 66 29 0a 3b  fine uidat #f).;
09b0: 3b 20 28 6d 65 67 61 74 65 73 74 2d 64 61 73 68  ; (megatest-dash
09c0: 62 6f 61 72 64 29 0a 0a 3b 28 64 65 66 69 6e 65  board)..;(define
09d0: 20 69 6d 67 31 20 28 69 75 70 3a 69 6d 61 67 65   img1 (iup:image
09e0: 2f 70 61 6c 65 74 74 65 20 31 36 20 31 36 20 28  /palette 16 16 (
09f0: 75 38 76 65 63 74 6f 72 2d 3e 62 6c 6f 62 20 28  u8vector->blob (
0a00: 75 38 76 65 63 74 6f 72 0a 3b 09 09 09 09 20 20  u8vector.;....  
0a10: 20 31 20 31 20 31 20 31 20 31 20 31 20 31 20 31   1 1 1 1 1 1 1 1
0a20: 20 31 20 31 20 31 20 31 20 31 20 31 20 31 20 32   1 1 1 1 1 1 1 2
0a30: 20 0a 3b 09 09 09 09 20 20 20 31 20 31 20 31 20   .;....   1 1 1 
0a40: 31 20 31 20 31 20 31 20 31 20 31 20 31 20 31 20  1 1 1 1 1 1 1 1 
0a50: 31 20 31 20 31 20 32 20 32 20 0a 3b 09 09 09 09  1 1 1 2 2 .;....
0a60: 20 20 20 31 20 31 20 31 20 31 20 31 20 31 20 31     1 1 1 1 1 1 1
0a70: 20 31 20 31 20 31 20 31 20 31 20 31 20 32 20 32   1 1 1 1 1 1 2 2
0a80: 20 32 20 0a 3b 09 09 09 09 20 20 20 31 20 31 20   2 .;....   1 1 
0a90: 31 20 31 20 31 20 31 20 31 20 31 20 31 20 31 20  1 1 1 1 1 1 1 1 
0aa0: 31 20 31 20 32 20 32 20 32 20 32 20 0a 3b 09 09  1 1 2 2 2 2 .;..
0ab0: 09 09 20 20 20 31 20 31 20 31 20 31 20 31 20 31  ..   1 1 1 1 1 1
0ac0: 20 31 20 31 20 31 20 31 20 31 20 32 20 32 20 32   1 1 1 1 1 2 2 2
0ad0: 20 32 20 32 20 0a 3b 09 09 09 09 20 20 20 31 20   2 2 .;....   1 
0ae0: 31 20 31 20 31 20 31 20 31 20 31 20 31 20 31 20  1 1 1 1 1 1 1 1 
0af0: 31 20 32 20 32 20 32 20 32 20 32 20 32 20 0a 3b  1 2 2 2 2 2 2 .;
0b00: 09 09 09 09 20 20 20 31 20 31 20 31 20 31 20 31  ....   1 1 1 1 1
0b10: 20 31 20 31 20 31 20 31 20 32 20 32 20 32 20 32   1 1 1 1 2 2 2 2
0b20: 20 32 20 32 20 32 20 0a 3b 09 09 09 09 20 20 20   2 2 2 .;....   
0b30: 31 20 31 20 31 20 31 20 31 20 31 20 31 20 31 20  1 1 1 1 1 1 1 1 
0b40: 32 20 32 20 32 20 32 20 32 20 32 20 32 20 32 20  2 2 2 2 2 2 2 2 
0b50: 0a 3b 09 09 09 09 20 20 20 32 20 32 20 32 20 32  .;....   2 2 2 2
0b60: 20 32 20 32 20 32 20 32 20 32 20 32 20 32 20 32   2 2 2 2 2 2 2 2
0b70: 20 32 20 32 20 32 20 32 20 0a 3b 09 09 09 09 20   2 2 2 2 .;.... 
0b80: 20 20 32 20 32 20 32 20 32 20 32 20 32 20 32 20    2 2 2 2 2 2 2 
0b90: 32 20 32 20 32 20 32 20 32 20 32 20 32 20 32 20  2 2 2 2 2 2 2 2 
0ba0: 32 20 0a 3b 09 09 09 09 20 20 20 32 20 32 20 32  2 .;....   2 2 2
0bb0: 20 30 20 32 20 32 20 32 20 32 20 32 20 32 20 32   0 2 2 2 2 2 2 2
0bc0: 20 32 20 32 20 32 20 32 20 32 20 0a 3b 09 09 09   2 2 2 2 2 .;...
0bd0: 09 20 20 20 32 20 32 20 32 20 30 20 32 20 32 20  .   2 2 2 0 2 2 
0be0: 32 20 32 20 32 20 32 20 32 20 32 20 32 20 32 20  2 2 2 2 2 2 2 2 
0bf0: 32 20 32 20 0a 3b 09 09 09 09 20 20 20 32 20 32  2 2 .;....   2 2
0c00: 20 32 20 30 20 32 20 30 20 32 20 30 20 32 20 32   2 0 2 0 2 0 2 2
0c10: 20 30 20 32 20 32 20 32 20 30 20 30 20 0a 3b 09   0 2 2 2 0 0 .;.
0c20: 09 09 09 20 20 20 32 20 32 20 32 20 30 20 32 20  ...   2 2 2 0 2 
0c30: 30 20 30 20 32 20 30 20 30 20 32 20 30 20 32 20  0 0 2 0 0 2 0 2 
0c40: 30 20 32 20 32 20 0a 3b 09 09 09 09 20 20 20 32  0 2 2 .;....   2
0c50: 20 32 20 32 20 30 20 32 20 30 20 32 20 32 20 30   2 2 0 2 0 2 2 0
0c60: 20 32 20 32 20 30 20 32 20 32 20 32 20 32 20 0a   2 2 0 2 2 2 2 .
0c70: 3b 09 09 09 09 20 20 20 32 20 32 20 32 20 30 20  ;....   2 2 2 0 
0c80: 32 20 30 20 32 20 32 20 30 20 32 20 32 20 30 20  2 0 2 2 0 2 2 0 
0c90: 32 20 32 20 30 20 30 20 0a 3b 09 09 09 09 20 20  2 2 0 0 .;....  
0ca0: 20 32 20 32 20 32 20 30 20 32 20 30 20 32 20 32   2 2 2 0 2 0 2 2
0cb0: 20 30 20 32 20 32 20 30 20 32 20 30 20 32 20 31   0 2 2 0 2 0 2 1
0cc0: 29 29 29 29 0a 3b 0a 3b 28 64 65 66 69 6e 65 20  )))).;.;(define 
0cd0: 69 6d 67 32 20 28 69 75 70 3a 69 6d 61 67 65 2f  img2 (iup:image/
0ce0: 70 61 6c 65 74 74 65 20 31 36 20 31 36 20 28 75  palette 16 16 (u
0cf0: 38 76 65 63 74 6f 72 2d 3e 62 6c 6f 62 20 28 75  8vector->blob (u
0d00: 38 76 65 63 74 6f 72 0a 3b 09 09 09 09 20 20 20  8vector.;....   
0d10: 32 20 32 20 32 20 32 20 32 20 32 20 32 20 32 20  2 2 2 2 2 2 2 2 
0d20: 32 20 32 20 32 20 32 20 32 20 32 20 32 20 31 20  2 2 2 2 2 2 2 1 
0d30: 0a 3b 09 09 09 09 20 20 20 32 20 32 20 32 20 32  .;....   2 2 2 2
0d40: 20 32 20 32 20 32 20 32 20 32 20 32 20 32 20 32   2 2 2 2 2 2 2 2
0d50: 20 32 20 32 20 31 20 31 20 0a 3b 09 09 09 09 20   2 2 1 1 .;.... 
0d60: 20 20 32 20 32 20 32 20 32 20 32 20 32 20 32 20    2 2 2 2 2 2 2 
0d70: 32 20 32 20 32 20 32 20 32 20 32 20 31 20 31 20  2 2 2 2 2 2 1 1 
0d80: 31 20 0a 3b 09 09 09 09 20 20 20 31 20 31 20 31  1 .;....   1 1 1
0d90: 20 31 20 31 20 31 20 31 20 31 20 31 20 31 20 31   1 1 1 1 1 1 1 1
0da0: 20 31 20 32 20 32 20 32 20 32 20 0a 3b 09 09 09   1 2 2 2 2 .;...
0db0: 09 20 20 20 31 20 31 20 31 20 31 20 31 20 31 20  .   1 1 1 1 1 1 
0dc0: 31 20 31 20 31 20 31 20 31 20 32 20 32 20 32 20  1 1 1 1 1 2 2 2 
0dd0: 32 20 32 20 0a 3b 09 09 09 09 20 20 20 31 20 31  2 2 .;....   1 1
0de0: 20 31 20 31 20 31 20 31 20 31 20 31 20 31 20 31   1 1 1 1 1 1 1 1
0df0: 20 32 20 32 20 32 20 32 20 32 20 32 20 0a 3b 09   2 2 2 2 2 2 .;.
0e00: 09 09 09 20 20 20 31 20 31 20 31 20 31 20 31 20  ...   1 1 1 1 1 
0e10: 31 20 31 20 31 20 31 20 32 20 32 20 32 20 32 20  1 1 1 1 2 2 2 2 
0e20: 32 20 32 20 32 20 0a 3b 09 09 09 09 20 20 20 31  2 2 2 .;....   1
0e30: 20 31 20 31 20 31 20 31 20 31 20 31 20 31 20 32   1 1 1 1 1 1 1 2
0e40: 20 32 20 32 20 32 20 32 20 32 20 32 20 32 20 0a   2 2 2 2 2 2 2 .
0e50: 3b 09 09 09 09 20 20 20 32 20 32 20 32 20 32 20  ;....   2 2 2 2 
0e60: 32 20 32 20 32 20 32 20 32 20 32 20 32 20 32 20  2 2 2 2 2 2 2 2 
0e70: 32 20 32 20 32 20 32 20 0a 3b 09 09 09 09 20 20  2 2 2 2 .;....  
0e80: 20 32 20 32 20 32 20 32 20 32 20 32 20 32 20 32   2 2 2 2 2 2 2 2
0e90: 20 32 20 32 20 32 20 32 20 32 20 32 20 32 20 32   2 2 2 2 2 2 2 2
0ea0: 20 0a 3b 09 09 09 09 20 20 20 32 20 32 20 32 20   .;....   2 2 2 
0eb0: 30 20 32 20 32 20 32 20 32 20 32 20 32 20 32 20  0 2 2 2 2 2 2 2 
0ec0: 32 20 32 20 32 20 32 20 32 20 0a 3b 09 09 09 09  2 2 2 2 2 .;....
0ed0: 20 20 20 32 20 32 20 32 20 30 20 32 20 32 20 32     2 2 2 0 2 2 2
0ee0: 20 32 20 32 20 32 20 32 20 32 20 32 20 32 20 32   2 2 2 2 2 2 2 2
0ef0: 20 32 20 0a 3b 09 09 09 09 20 20 20 32 20 32 20   2 .;....   2 2 
0f00: 32 20 30 20 32 20 30 20 32 20 30 20 32 20 32 20  2 0 2 0 2 0 2 2 
0f10: 30 20 32 20 32 20 32 20 30 20 30 20 0a 3b 09 09  0 2 2 2 0 0 .;..
0f20: 09 09 20 20 20 32 20 32 20 32 20 30 20 32 20 30  ..   2 2 2 0 2 0
0f30: 20 30 20 32 20 30 20 30 20 32 20 30 20 32 20 30   0 2 0 0 2 0 2 0
0f40: 20 32 20 32 20 0a 3b 09 09 09 09 20 20 20 32 20   2 2 .;....   2 
0f50: 32 20 32 20 30 20 32 20 30 20 32 20 32 20 30 20  2 2 0 2 0 2 2 0 
0f60: 32 20 32 20 30 20 32 20 32 20 32 20 32 20 0a 3b  2 2 0 2 2 2 2 .;
0f70: 09 09 09 09 20 20 20 32 20 32 20 32 20 30 20 32  ....   2 2 2 0 2
0f80: 20 30 20 32 20 32 20 30 20 32 20 32 20 30 20 32   0 2 2 0 2 2 0 2
0f90: 20 32 20 30 20 30 20 0a 3b 09 09 09 09 20 20 20   2 0 0 .;....   
0fa0: 32 20 32 20 32 20 30 20 32 20 30 20 32 20 32 20  2 2 2 0 2 0 2 2 
0fb0: 30 20 32 20 32 20 30 20 32 20 30 20 32 20 31 29  0 2 2 0 2 0 2 1)
0fc0: 29 29 29 0a 3b 0a 3b 28 69 75 70 3a 68 61 6e 64  ))).;.;(iup:hand
0fd0: 6c 65 2d 6e 61 6d 65 2d 73 65 74 21 20 69 6d 67  le-name-set! img
0fe0: 31 20 22 69 6d 67 31 22 29 0a 3b 28 69 75 70 3a  1 "img1").;(iup:
0ff0: 61 74 74 72 69 62 75 74 65 2d 73 65 74 21 20 69  attribute-set! i
1000: 6d 67 31 20 22 30 22 20 22 30 20 30 20 30 22 29  mg1 "0" "0 0 0")
1010: 0a 3b 28 69 75 70 3a 61 74 74 72 69 62 75 74 65  .;(iup:attribute
1020: 2d 73 65 74 21 20 69 6d 67 31 20 22 31 22 20 22  -set! img1 "1" "
1030: 42 47 43 4f 4c 4f 52 22 29 0a 3b 28 69 75 70 3a  BGCOLOR").;(iup:
1040: 61 74 74 72 69 62 75 74 65 2d 73 65 74 21 20 69  attribute-set! i
1050: 6d 67 31 20 22 32 22 20 22 32 35 35 20 30 20 30  mg1 "2" "255 0 0
1060: 22 29 0a 3b 0a 3b 28 69 75 70 3a 68 61 6e 64 6c  ").;.;(iup:handl
1070: 65 2d 6e 61 6d 65 2d 73 65 74 21 20 69 6d 67 32  e-name-set! img2
1080: 20 22 69 6d 67 32 22 29 0a 3b 28 69 75 70 3a 61   "img2").;(iup:a
1090: 74 74 72 69 62 75 74 65 2d 73 65 74 21 20 69 6d  ttribute-set! im
10a0: 67 32 20 22 30 22 20 22 30 20 30 20 30 22 29 0a  g2 "0" "0 0 0").
10b0: 3b 28 69 75 70 3a 61 74 74 72 69 62 75 74 65 2d  ;(iup:attribute-
10c0: 73 65 74 21 20 69 6d 67 32 20 22 31 22 20 22 42  set! img2 "1" "B
10d0: 47 43 4f 4c 4f 52 22 29 0a 3b 28 69 75 70 3a 61  GCOLOR").;(iup:a
10e0: 74 74 72 69 62 75 74 65 2d 73 65 74 21 20 69 6d  ttribute-set! im
10f0: 67 32 20 22 32 22 20 22 32 35 35 20 30 20 30 22  g2 "2" "255 0 0"
1100: 29 0a 0a 28 64 65 66 69 6e 65 20 28 6d 65 73 73  )..(define (mess
1110: 61 67 65 2d 77 69 6e 64 6f 77 20 6d 73 67 29 0a  age-window msg).
1120: 20 20 28 69 75 70 3a 73 68 6f 77 0a 20 20 20 28    (iup:show.   (
1130: 69 75 70 3a 64 69 61 6c 6f 67 0a 20 20 20 20 28  iup:dialog.    (
1140: 69 75 70 3a 76 62 6f 78 20 0a 20 20 20 20 20 28  iup:vbox .     (
1150: 69 75 70 3a 6c 61 62 65 6c 20 6d 73 67 20 23 3a  iup:label msg #:
1160: 6d 61 72 67 69 6e 20 22 34 30 78 34 30 22 29 29  margin "40x40"))
1170: 29 29 29 0a 0a 28 64 65 66 69 6e 65 20 28 69 75  )))..(define (iu
1180: 70 6c 69 73 74 62 6f 78 2d 66 69 6c 6c 2d 6c 69  plistbox-fill-li
1190: 73 74 20 6c 62 20 69 74 65 6d 73 20 2e 20 64 65  st lb items . de
11a0: 66 61 75 6c 74 29 0a 20 20 28 6c 65 74 20 28 28  fault).  (let ((
11b0: 69 20 31 29 0a 09 28 73 65 6c 65 63 74 65 64 2d  i 1)..(selected-
11c0: 69 74 65 6d 20 28 69 66 20 28 6e 75 6c 6c 3f 20  item (if (null? 
11d0: 64 65 66 61 75 6c 74 29 20 23 66 20 28 63 61 72  default) #f (car
11e0: 20 64 65 66 61 75 6c 74 29 29 29 29 0a 20 20 20   default)))).   
11f0: 20 28 69 75 70 3a 61 74 74 72 69 62 75 74 65 2d   (iup:attribute-
1200: 73 65 74 21 20 6c 62 20 22 56 41 4c 55 45 22 20  set! lb "VALUE" 
1210: 28 69 66 20 73 65 6c 65 63 74 65 64 2d 69 74 65  (if selected-ite
1220: 6d 20 73 65 6c 65 63 74 65 64 2d 69 74 65 6d 20  m selected-item 
1230: 22 22 29 29 0a 20 20 20 20 28 66 6f 72 2d 65 61  "")).    (for-ea
1240: 63 68 20 28 6c 61 6d 62 64 61 20 28 69 74 65 6d  ch (lambda (item
1250: 29 0a 09 09 28 69 75 70 3a 61 74 74 72 69 62 75  )...(iup:attribu
1260: 74 65 2d 73 65 74 21 20 6c 62 20 28 6e 75 6d 62  te-set! lb (numb
1270: 65 72 2d 3e 73 74 72 69 6e 67 20 69 29 20 69 74  er->string i) it
1280: 65 6d 29 0a 09 09 28 69 66 20 73 65 6c 65 63 74  em)...(if select
1290: 65 64 2d 69 74 65 6d 0a 09 09 20 20 20 20 28 69  ed-item...    (i
12a0: 66 20 28 65 71 75 61 6c 3f 20 73 65 6c 65 63 74  f (equal? select
12b0: 65 64 2d 69 74 65 6d 20 69 74 65 6d 29 0a 09 09  ed-item item)...
12c0: 09 28 69 75 70 3a 61 74 74 72 69 62 75 74 65 2d  .(iup:attribute-
12d0: 73 65 74 21 20 6c 62 20 22 56 41 4c 55 45 22 20  set! lb "VALUE" 
12e0: 69 74 65 6d 29 29 29 20 3b 3b 20 28 6e 75 6d 62  item))) ;; (numb
12f0: 65 72 2d 3e 73 74 72 69 6e 67 20 69 29 29 29 29  er->string i))))
1300: 0a 09 09 28 73 65 74 21 20 69 20 28 2b 20 69 20  ...(set! i (+ i 
1310: 31 29 29 29 0a 09 20 20 20 20 20 20 69 74 65 6d  1)))..      item
1320: 73 29 0a 20 20 20 20 69 29 29 0a 0a 28 64 65 66  s).    i))..(def
1330: 69 6e 65 20 28 70 61 64 2d 6c 69 73 74 20 6c 20  ine (pad-list l 
1340: 6e 29 28 61 70 70 65 6e 64 20 6c 20 28 6d 61 6b  n)(append l (mak
1350: 65 2d 6c 69 73 74 20 28 2d 20 6e 20 28 6c 65 6e  e-list (- n (len
1360: 67 74 68 20 6c 29 29 29 29 29 0a 0a 28 64 65 66  gth l)))))..(def
1370: 69 6e 65 20 28 63 6f 6c 6f 72 73 2d 73 69 6d 69  ine (colors-simi
1380: 6c 61 72 3f 20 63 6f 6c 6f 72 31 20 63 6f 6c 6f  lar? color1 colo
1390: 72 32 29 0a 20 20 28 6c 65 74 2a 20 28 28 63 31  r2).  (let* ((c1
13a0: 20 28 6d 61 70 20 73 74 72 69 6e 67 2d 3e 6e 75   (map string->nu
13b0: 6d 62 65 72 20 28 73 74 72 69 6e 67 2d 73 70 6c  mber (string-spl
13c0: 69 74 20 63 6f 6c 6f 72 31 29 29 29 0a 09 20 28  it color1))).. (
13d0: 63 32 20 28 6d 61 70 20 73 74 72 69 6e 67 2d 3e  c2 (map string->
13e0: 6e 75 6d 62 65 72 20 28 73 74 72 69 6e 67 2d 73  number (string-s
13f0: 70 6c 69 74 20 63 6f 6c 6f 72 32 29 29 29 0a 09  plit color2)))..
1400: 20 28 64 65 6c 74 61 20 28 6d 61 70 20 28 6c 61   (delta (map (la
1410: 6d 62 64 61 20 28 61 20 62 29 28 61 62 73 20 28  mbda (a b)(abs (
1420: 2d 20 61 20 62 29 29 29 20 63 31 20 63 32 29 29  - a b))) c1 c2))
1430: 29 0a 20 20 20 20 28 6e 75 6c 6c 3f 20 28 66 69  ).    (null? (fi
1440: 6c 74 65 72 20 28 6c 61 6d 62 64 61 20 28 78 29  lter (lambda (x)
1450: 28 3e 20 78 20 33 29 29 20 64 65 6c 74 61 29 29  (> x 3)) delta))
1460: 29 29 0a 0a 28 64 65 66 69 6e 65 20 28 75 70 64  ))..(define (upd
1470: 61 74 65 2d 72 75 6e 64 61 74 20 72 75 6e 6e 61  ate-rundat runna
1480: 6d 65 70 61 74 74 20 6e 75 6d 72 75 6e 73 20 74  mepatt numruns t
1490: 65 73 74 6e 61 6d 65 70 61 74 74 20 69 74 65 6d  estnamepatt item
14a0: 6e 61 6d 65 70 61 74 74 29 0a 20 20 28 6c 65 74  namepatt).  (let
14b0: 2a 20 28 28 61 6c 6c 72 75 6e 73 20 20 20 20 20  * ((allruns     
14c0: 28 64 62 2d 67 65 74 2d 72 75 6e 73 20 2a 64 62  (db-get-runs *db
14d0: 2a 20 72 75 6e 6e 61 6d 65 70 61 74 74 20 6e 75  * runnamepatt nu
14e0: 6d 72 75 6e 73 20 2a 73 74 61 72 74 2d 72 75 6e  mruns *start-run
14f0: 2d 6f 66 66 73 65 74 2a 29 29 0a 09 20 28 68 65  -offset*)).. (he
1500: 61 64 65 72 20 20 20 20 20 20 28 64 62 3a 67 65  ader      (db:ge
1510: 74 2d 68 65 61 64 65 72 20 61 6c 6c 72 75 6e 73  t-header allruns
1520: 29 29 0a 09 20 28 72 75 6e 73 20 20 20 20 20 20  )).. (runs      
1530: 20 20 28 64 62 3a 67 65 74 2d 72 6f 77 73 20 20    (db:get-rows  
1540: 20 61 6c 6c 72 75 6e 73 29 29 0a 09 20 28 72 65   allruns)).. (re
1550: 73 75 6c 74 20 20 20 20 20 20 27 28 29 29 0a 09  sult      '())..
1560: 20 28 6d 61 78 74 65 73 74 73 20 20 20 20 30 29   (maxtests    0)
1570: 29 0a 20 20 20 20 28 66 6f 72 2d 65 61 63 68 20  ).    (for-each 
1580: 28 6c 61 6d 62 64 61 20 28 72 75 6e 29 0a 09 09  (lambda (run)...
1590: 28 6c 65 74 2a 20 28 28 72 75 6e 2d 69 64 20 20  (let* ((run-id  
15a0: 20 28 64 62 3a 67 65 74 2d 76 61 6c 75 65 2d 62   (db:get-value-b
15b0: 79 2d 68 65 61 64 65 72 20 72 75 6e 20 68 65 61  y-header run hea
15c0: 64 65 72 20 22 69 64 22 29 29 0a 09 09 20 20 20  der "id"))...   
15d0: 20 20 20 20 28 74 65 73 74 73 20 20 20 20 28 64      (tests    (d
15e0: 62 2d 67 65 74 2d 74 65 73 74 73 2d 66 6f 72 2d  b-get-tests-for-
15f0: 72 75 6e 20 2a 64 62 2a 20 72 75 6e 2d 69 64 20  run *db* run-id 
1600: 74 65 73 74 6e 61 6d 65 70 61 74 74 20 69 74 65  testnamepatt ite
1610: 6d 6e 61 6d 65 70 61 74 74 29 29 0a 09 09 20 20  mnamepatt))...  
1620: 20 20 20 20 20 28 6b 65 79 2d 76 61 6c 73 20 28       (key-vals (
1630: 67 65 74 2d 6b 65 79 2d 76 61 6c 73 20 2a 64 62  get-key-vals *db
1640: 2a 20 72 75 6e 2d 69 64 29 29 29 0a 09 09 20 20  * run-id)))...  
1650: 28 69 66 20 28 3e 20 28 6c 65 6e 67 74 68 20 74  (if (> (length t
1660: 65 73 74 73 29 20 6d 61 78 74 65 73 74 73 29 0a  ests) maxtests).
1670: 09 09 20 20 20 20 20 20 28 73 65 74 21 20 6d 61  ..      (set! ma
1680: 78 74 65 73 74 73 20 28 6c 65 6e 67 74 68 20 74  xtests (length t
1690: 65 73 74 73 29 29 29 0a 09 09 20 20 28 73 65 74  ests)))...  (set
16a0: 21 20 72 65 73 75 6c 74 20 28 63 6f 6e 73 20 28  ! result (cons (
16b0: 76 65 63 74 6f 72 20 72 75 6e 20 74 65 73 74 73  vector run tests
16c0: 20 6b 65 79 2d 76 61 6c 73 29 20 72 65 73 75 6c   key-vals) resul
16d0: 74 29 29 29 29 0a 09 20 20 20 20 20 20 72 75 6e  t))))..      run
16e0: 73 29 0a 20 20 20 20 28 73 65 74 21 20 2a 68 65  s).    (set! *he
16f0: 61 64 65 72 2a 20 20 68 65 61 64 65 72 29 0a 20  ader*  header). 
1700: 20 20 20 28 73 65 74 21 20 2a 61 6c 6c 72 75 6e     (set! *allrun
1710: 73 2a 20 72 65 73 75 6c 74 29 0a 20 20 20 20 6d  s* result).    m
1720: 61 78 74 65 73 74 73 29 29 0a 0a 28 64 65 66 69  axtests))..(defi
1730: 6e 65 20 2a 63 6f 6c 6c 61 70 73 65 64 2a 20 28  ne *collapsed* (
1740: 6d 61 6b 65 2d 68 61 73 68 2d 74 61 62 6c 65 29  make-hash-table)
1750: 29 0a 3b 20 28 64 65 66 69 6e 65 20 2a 72 6f 77  ).; (define *row
1760: 2d 6c 6f 6f 6b 75 70 2a 20 28 6d 61 6b 65 2d 68  -lookup* (make-h
1770: 61 73 68 2d 74 61 62 6c 65 29 29 20 3b 3b 20 74  ash-table)) ;; t
1780: 65 73 74 6e 61 6d 65 20 3d 3e 20 28 72 6f 77 6e  estname => (rown
1790: 75 6d 20 6c 61 62 6c 65 6f 62 6a 29 0a 0a 28 64  um lableobj)..(d
17a0: 65 66 69 6e 65 20 28 74 6f 67 67 6c 65 2d 68 69  efine (toggle-hi
17b0: 64 65 20 6c 6e 75 6d 29 20 3b 20 66 75 6c 6c 74  de lnum) ; fullt
17c0: 65 73 74 6e 61 6d 65 29 0a 20 20 28 6c 65 74 2a  estname).  (let*
17d0: 20 28 28 62 74 6e 20 28 76 65 63 74 6f 72 2d 72   ((btn (vector-r
17e0: 65 66 20 28 76 65 63 74 6f 72 2d 72 65 66 20 75  ef (vector-ref u
17f0: 69 64 61 74 20 30 29 20 6c 6e 75 6d 29 29 0a 09  idat 0) lnum))..
1800: 20 28 66 75 6c 6c 74 65 73 74 6e 61 6d 65 20 28   (fulltestname (
1810: 69 75 70 3a 61 74 74 72 69 62 75 74 65 20 62 74  iup:attribute bt
1820: 6e 20 22 54 49 54 4c 45 22 29 29 0a 09 20 28 70  n "TITLE")).. (p
1830: 61 72 74 73 20 20 20 20 20 20 20 20 28 73 74 72  arts        (str
1840: 69 6e 67 2d 73 70 6c 69 74 20 66 75 6c 6c 74 65  ing-split fullte
1850: 73 74 6e 61 6d 65 20 22 28 22 29 29 0a 09 20 28  stname "(")).. (
1860: 62 61 73 65 74 65 73 74 6e 61 6d 65 20 28 69 66  basetestname (if
1870: 20 28 6e 75 6c 6c 3f 20 70 61 72 74 73 29 20 22   (null? parts) "
1880: 22 20 28 63 61 72 20 70 61 72 74 73 29 29 29 29  " (car parts))))
1890: 0a 20 20 20 20 3b 28 70 72 69 6e 74 20 22 54 6f  .    ;(print "To
18a0: 67 67 6c 69 6e 67 20 22 20 62 61 73 65 74 65 73  ggling " basetes
18b0: 74 6e 61 6d 65 20 22 20 63 75 72 72 65 6e 74 6c  tname " currentl
18c0: 79 20 22 20 28 68 61 73 68 2d 74 61 62 6c 65 2d  y " (hash-table-
18d0: 72 65 66 2f 64 65 66 61 75 6c 74 20 2a 63 6f 6c  ref/default *col
18e0: 6c 61 70 73 65 64 2a 20 62 61 73 65 74 65 73 74  lapsed* basetest
18f0: 6e 61 6d 65 20 23 66 29 29 0a 20 20 20 20 28 69  name #f)).    (i
1900: 66 20 28 68 61 73 68 2d 74 61 62 6c 65 2d 72 65  f (hash-table-re
1910: 66 2f 64 65 66 61 75 6c 74 20 2a 63 6f 6c 6c 61  f/default *colla
1920: 70 73 65 64 2a 20 62 61 73 65 74 65 73 74 6e 61  psed* basetestna
1930: 6d 65 20 23 66 29 0a 09 28 62 65 67 69 6e 0a 09  me #f)..(begin..
1940: 20 20 3b 28 69 75 70 3a 61 74 74 72 69 62 75 74    ;(iup:attribut
1950: 65 2d 73 65 74 21 20 62 74 6e 20 22 46 47 43 4f  e-set! btn "FGCO
1960: 4c 4f 52 22 20 22 30 20 30 20 30 22 29 0a 09 20  LOR" "0 0 0").. 
1970: 20 28 68 61 73 68 2d 74 61 62 6c 65 2d 64 65 6c   (hash-table-del
1980: 65 74 65 21 20 2a 63 6f 6c 6c 61 70 73 65 64 2a  ete! *collapsed*
1990: 20 62 61 73 65 74 65 73 74 6e 61 6d 65 29 29 0a   basetestname)).
19a0: 09 28 62 65 67 69 6e 0a 09 20 20 3b 28 69 75 70  .(begin..  ;(iup
19b0: 3a 61 74 74 72 69 62 75 74 65 2d 73 65 74 21 20  :attribute-set! 
19c0: 62 74 6e 20 22 46 47 43 4f 4c 4f 52 22 20 22 30  btn "FGCOLOR" "0
19d0: 20 31 39 32 20 31 39 32 22 29 0a 09 20 20 28 68   192 192")..  (h
19e0: 61 73 68 2d 74 61 62 6c 65 2d 73 65 74 21 20 2a  ash-table-set! *
19f0: 63 6f 6c 6c 61 70 73 65 64 2a 20 62 61 73 65 74  collapsed* baset
1a00: 65 73 74 6e 61 6d 65 20 23 74 29 29 29 29 29 0a  estname #t))))).
1a10: 20 20 0a 28 64 65 66 69 6e 65 20 62 6c 61 6e 6b    .(define blank
1a20: 2d 6c 69 6e 65 2d 72 78 20 28 72 65 67 65 78 70  -line-rx (regexp
1a30: 20 22 5e 5c 5c 73 2a 24 22 29 29 0a 0a 28 64 65   "^\\s*$"))..(de
1a40: 66 69 6e 65 20 28 63 6f 6c 6c 61 70 73 65 2d 72  fine (collapse-r
1a50: 6f 77 73 20 69 6e 6c 73 74 29 0a 20 20 28 6c 65  ows inlst).  (le
1a60: 74 20 28 28 6e 65 77 6c 73 74 20 28 66 69 6c 74  t ((newlst (filt
1a70: 65 72 20 28 6c 61 6d 62 64 61 20 28 78 29 0a 09  er (lambda (x)..
1a80: 09 09 20 20 28 6c 65 74 2a 20 28 28 74 70 61 72  ..  (let* ((tpar
1a90: 74 73 20 20 20 20 28 73 74 72 69 6e 67 2d 73 70  ts    (string-sp
1aa0: 6c 69 74 20 78 20 22 28 22 29 29 0a 09 09 09 09  lit x "(")).....
1ab0: 20 28 62 61 73 65 74 6e 61 6d 65 20 28 69 66 20   (basetname (if 
1ac0: 28 6e 75 6c 6c 3f 20 74 70 61 72 74 73 29 20 78  (null? tparts) x
1ad0: 20 28 63 61 72 20 74 70 61 72 74 73 29 29 29 29   (car tparts))))
1ae0: 0a 09 09 09 09 09 3b 28 70 72 69 6e 74 20 22 78  ......;(print "x
1af0: 20 22 20 78 20 22 20 74 70 61 72 74 73 3a 20 22   " x " tparts: "
1b00: 20 74 70 61 72 74 73 20 22 20 62 61 73 65 74 6e   tparts " basetn
1b10: 61 6d 65 3a 20 22 20 62 61 73 65 74 6e 61 6d 65  ame: " basetname
1b20: 29 0a 09 09 09 20 20 20 20 28 63 6f 6e 64 0a 09  )....    (cond..
1b30: 09 09 20 20 20 20 20 28 28 73 74 72 69 6e 67 2d  ..     ((string-
1b40: 6d 61 74 63 68 20 62 6c 61 6e 6b 2d 6c 69 6e 65  match blank-line
1b50: 2d 72 78 20 78 29 20 23 66 29 0a 09 09 09 20 20  -rx x) #f)....  
1b60: 20 20 20 28 28 65 71 75 61 6c 3f 20 78 20 62 61     ((equal? x ba
1b70: 73 65 74 6e 61 6d 65 29 20 23 74 29 0a 09 09 09  setname) #t)....
1b80: 20 20 20 20 20 28 28 68 61 73 68 2d 74 61 62 6c       ((hash-tabl
1b90: 65 2d 72 65 66 2f 64 65 66 61 75 6c 74 20 2a 63  e-ref/default *c
1ba0: 6f 6c 6c 61 70 73 65 64 2a 20 62 61 73 65 74 6e  ollapsed* basetn
1bb0: 61 6d 65 20 23 66 29 20 0a 09 09 09 09 09 3b 28  ame #f) ......;(
1bc0: 70 72 69 6e 74 20 22 52 65 6d 6f 76 69 6e 67 20  print "Removing 
1bd0: 22 20 62 61 73 65 74 6e 61 6d 65 20 22 20 66 72  " basetname " fr
1be0: 6f 6d 20 69 74 65 6d 73 22 29 0a 09 09 09 20 20  om items")....  
1bf0: 20 20 20 20 23 66 29 0a 09 09 09 20 20 20 20 20      #f)....     
1c00: 28 65 6c 73 65 20 23 74 29 29 29 29 0a 09 09 09  (else #t))))....
1c10: 69 6e 6c 73 74 29 29 29 0a 20 20 20 20 3b 3b 20  inlst))).    ;; 
1c20: 73 70 65 63 69 61 6c 20 73 6f 72 74 20 74 6f 20  special sort to 
1c30: 70 75 73 68 20 74 68 65 20 74 65 73 74 28 69 74  push the test(it
1c40: 65 6d 29 20 74 6f 20 61 66 74 65 72 20 74 65 73  em) to after tes
1c50: 74 0a 20 20 20 20 28 73 6f 72 74 20 6e 65 77 6c  t.    (sort newl
1c60: 73 74 20 28 6c 61 6d 62 64 61 20 28 61 20 62 29  st (lambda (a b)
1c70: 0a 09 09 20 20 20 28 6c 65 74 2a 20 28 28 70 61  ...   (let* ((pa
1c80: 72 74 73 61 20 28 73 74 72 69 6e 67 2d 73 70 6c  rtsa (string-spl
1c90: 69 74 20 61 20 22 28 22 29 29 0a 09 09 09 20 20  it a "("))....  
1ca0: 28 70 61 72 74 73 62 20 28 73 74 72 69 6e 67 2d  (partsb (string-
1cb0: 73 70 6c 69 74 20 62 20 22 28 22 29 29 0a 09 09  split b "("))...
1cc0: 09 20 20 28 6c 65 6e 61 20 20 20 28 6c 65 6e 67  .  (lena   (leng
1cd0: 74 68 20 70 61 72 74 73 61 29 29 0a 09 09 09 20  th partsa)).... 
1ce0: 20 28 6c 65 6e 62 20 20 20 28 6c 65 6e 67 74 68   (lenb   (length
1cf0: 20 70 61 72 74 73 62 29 29 29 0a 09 09 20 20 20   partsb)))...   
1d00: 20 20 28 69 66 20 28 6f 72 20 28 61 6e 64 20 28    (if (or (and (
1d10: 65 71 3f 20 6c 65 6e 61 20 31 29 28 3e 20 6c 65  eq? lena 1)(> le
1d20: 6e 62 20 31 29 29 0a 09 09 09 20 20 20 20 20 28  nb 1))....     (
1d30: 61 6e 64 20 28 65 71 3f 20 6c 65 6e 62 20 31 29  and (eq? lenb 1)
1d40: 28 3e 20 6c 65 6e 61 20 31 29 29 29 0a 09 09 09  (> lena 1)))....
1d50: 20 28 69 66 20 28 65 71 75 61 6c 3f 20 28 63 61   (if (equal? (ca
1d60: 72 20 70 61 72 74 73 61 29 28 63 61 72 20 70 61  r partsa)(car pa
1d70: 72 74 73 62 29 29 20 3b 3b 20 73 61 6d 65 20 74  rtsb)) ;; same t
1d80: 65 73 74 0a 09 09 09 20 20 20 20 20 28 3e 20 6c  est....     (> l
1d90: 65 6e 62 20 6c 65 6e 61 29 0a 09 09 09 20 20 20  enb lena)....   
1da0: 20 20 23 74 29 0a 09 09 09 20 23 74 29 29 29 29    #t).... #t))))
1db0: 29 29 0a 09 09 09 20 20 20 20 20 0a 28 64 65 66  ))....     .(def
1dc0: 69 6e 65 20 28 75 70 64 61 74 65 2d 6c 61 62 65  ine (update-labe
1dd0: 6c 73 20 75 69 64 61 74 29 0a 20 20 28 6c 65 74  ls uidat).  (let
1de0: 2a 20 28 28 72 6f 77 6e 20 20 20 20 30 29 0a 09  * ((rown    0)..
1df0: 20 28 6c 66 74 63 6f 6c 20 20 28 76 65 63 74 6f   (lftcol  (vecto
1e00: 72 2d 72 65 66 20 75 69 64 61 74 20 30 29 29 0a  r-ref uidat 0)).
1e10: 09 20 28 6e 75 6d 63 6f 6c 73 20 28 76 65 63 74  . (numcols (vect
1e20: 6f 72 2d 6c 65 6e 67 74 68 20 6c 66 74 63 6f 6c  or-length lftcol
1e30: 29 29 0a 09 20 28 6d 61 78 6e 20 20 20 20 28 2d  )).. (maxn    (-
1e40: 20 6e 75 6d 63 6f 6c 73 20 31 29 29 0a 09 20 28   numcols 1)).. (
1e50: 61 6c 6c 76 61 6c 73 20 28 6d 61 6b 65 2d 76 65  allvals (make-ve
1e60: 63 74 6f 72 20 6e 75 6d 63 6f 6c 73 20 22 22 29  ctor numcols "")
1e70: 29 29 0a 20 20 20 20 28 66 6f 72 2d 65 61 63 68  )).    (for-each
1e80: 20 28 6c 61 6d 62 64 61 20 28 6e 61 6d 65 29 0a   (lambda (name).
1e90: 09 09 28 69 66 20 28 3c 3d 20 72 6f 77 6e 20 6d  ..(if (<= rown m
1ea0: 61 78 6e 29 0a 09 09 20 20 20 20 28 6c 65 74 20  axn)...    (let 
1eb0: 28 28 6c 61 62 6c 20 28 76 65 63 74 6f 72 2d 72  ((labl (vector-r
1ec0: 65 66 20 6c 66 74 63 6f 6c 20 72 6f 77 6e 29 29  ef lftcol rown))
1ed0: 29 0a 09 09 20 20 20 20 20 20 28 76 65 63 74 6f  )...      (vecto
1ee0: 72 2d 73 65 74 21 20 61 6c 6c 76 61 6c 73 20 72  r-set! allvals r
1ef0: 6f 77 6e 20 6e 61 6d 65 29 29 29 0a 09 09 28 73  own name)))...(s
1f00: 65 74 21 20 72 6f 77 6e 20 28 2b 20 31 20 72 6f  et! rown (+ 1 ro
1f10: 77 6e 29 29 29 0a 09 20 20 20 20 20 20 2a 61 6c  wn)))..      *al
1f20: 6c 74 65 73 74 6e 61 6d 65 6c 73 74 2a 29 0a 09  ltestnamelst*)..
1f30: 3b 20 20 20 20 20 20 28 69 66 20 28 3e 20 28 6c  ;      (if (> (l
1f40: 65 6e 67 74 68 20 2a 61 6c 6c 74 65 73 74 6e 61  ength *alltestna
1f50: 6d 65 6c 73 74 2a 29 20 2a 73 74 61 72 74 2d 74  melst*) *start-t
1f60: 65 73 74 2d 6f 66 66 73 65 74 2a 29 0a 09 3b 09  est-offset*)..;.
1f70: 20 20 28 64 72 6f 70 20 2a 61 6c 6c 74 65 73 74    (drop *alltest
1f80: 6e 61 6d 65 6c 73 74 2a 20 2a 73 74 61 72 74 2d  namelst* *start-
1f90: 74 65 73 74 2d 6f 66 66 73 65 74 2a 29 0a 09 3b  test-offset*)..;
1fa0: 09 20 20 27 28 29 29 29 0a 20 20 20 20 28 6c 65  .  '())).    (le
1fb0: 74 20 6c 6f 6f 70 20 28 28 69 20 30 29 29 0a 20  t loop ((i 0)). 
1fc0: 20 20 20 20 20 28 6c 65 74 2a 20 28 28 6c 62 6c       (let* ((lbl
1fd0: 20 20 20 20 28 76 65 63 74 6f 72 2d 72 65 66 20      (vector-ref 
1fe0: 6c 66 74 63 6f 6c 20 69 29 29 0a 09 20 20 20 20  lftcol i))..    
1ff0: 20 28 6f 6c 64 76 61 6c 20 28 69 75 70 3a 61 74   (oldval (iup:at
2000: 74 72 69 62 75 74 65 20 6c 62 6c 20 22 54 49 54  tribute lbl "TIT
2010: 4c 45 22 29 29 0a 09 20 20 20 20 20 28 6e 65 77  LE"))..     (new
2020: 76 61 6c 20 28 76 65 63 74 6f 72 2d 72 65 66 20  val (vector-ref 
2030: 61 6c 6c 76 61 6c 73 20 69 29 29 29 0a 09 28 69  allvals i)))..(i
2040: 66 20 28 6e 6f 74 20 28 65 71 75 61 6c 3f 20 6f  f (not (equal? o
2050: 6c 64 76 61 6c 20 6e 65 77 76 61 6c 29 29 0a 09  ldval newval))..
2060: 20 20 20 20 28 69 75 70 3a 61 74 74 72 69 62 75      (iup:attribu
2070: 74 65 2d 73 65 74 21 20 6c 62 6c 20 22 54 49 54  te-set! lbl "TIT
2080: 4c 45 22 20 6e 65 77 76 61 6c 29 29 0a 09 28 69  LE" newval))..(i
2090: 75 70 3a 61 74 74 72 69 62 75 74 65 2d 73 65 74  up:attribute-set
20a0: 21 20 6c 62 6c 20 22 46 47 43 4f 4c 4f 52 22 20  ! lbl "FGCOLOR" 
20b0: 28 69 66 20 28 68 61 73 68 2d 74 61 62 6c 65 2d  (if (hash-table-
20c0: 72 65 66 2f 64 65 66 61 75 6c 74 20 2a 63 6f 6c  ref/default *col
20d0: 6c 61 70 73 65 64 2a 20 6e 65 77 76 61 6c 20 23  lapsed* newval #
20e0: 66 29 20 22 30 20 31 31 32 20 31 31 32 22 20 22  f) "0 112 112" "
20f0: 30 20 30 20 30 22 29 29 0a 09 28 69 66 20 28 3c  0 0 0"))..(if (<
2100: 20 69 20 6d 61 78 6e 29 0a 09 20 20 20 20 28 6c   i maxn)..    (l
2110: 6f 6f 70 20 28 2b 20 69 20 31 29 29 29 29 29 29  oop (+ i 1))))))
2120: 29 0a 0a 28 64 65 66 69 6e 65 20 28 67 65 74 2d  )..(define (get-
2130: 63 6f 6c 6f 72 2d 66 6f 72 2d 73 74 61 74 65 2d  color-for-state-
2140: 73 74 61 74 75 73 20 73 74 61 74 65 20 73 74 61  status state sta
2150: 74 75 73 29 0a 20 20 28 63 61 73 65 20 28 73 74  tus).  (case (st
2160: 72 69 6e 67 2d 3e 73 79 6d 62 6f 6c 20 73 74 61  ring->symbol sta
2170: 74 65 29 0a 20 20 20 20 28 28 43 4f 4d 50 4c 45  te).    ((COMPLE
2180: 54 45 44 29 0a 20 20 20 20 20 28 69 66 20 28 65  TED).     (if (e
2190: 71 75 61 6c 3f 20 73 74 61 74 75 73 20 22 50 41  qual? status "PA
21a0: 53 53 22 29 0a 09 20 22 37 30 20 32 34 39 20 37  SS").. "70 249 7
21b0: 33 22 0a 09 20 28 69 66 20 28 6f 72 20 28 65 71  3".. (if (or (eq
21c0: 75 61 6c 3f 20 73 74 61 74 75 73 20 22 57 41 52  ual? status "WAR
21d0: 4e 22 29 0a 09 09 20 28 65 71 75 61 6c 3f 20 73  N")... (equal? s
21e0: 74 61 74 75 73 20 22 57 41 49 56 45 44 22 29 29  tatus "WAIVED"))
21f0: 0a 09 20 20 20 20 20 22 32 35 35 20 31 37 32 20  ..     "255 172 
2200: 31 33 22 0a 09 20 20 20 20 20 22 32 32 33 20 33  13"..     "223 3
2210: 33 20 34 39 22 29 29 29 20 3b 3b 20 67 72 65 65  3 49"))) ;; gree
2220: 6e 69 73 68 20 6f 72 61 6e 67 65 69 73 68 20 72  nish orangeish r
2230: 65 64 69 73 68 0a 20 20 20 20 28 28 4c 41 55 4e  edish.    ((LAUN
2240: 43 48 45 44 29 20 20 20 20 20 20 20 20 20 22 31  CHED)         "1
2250: 30 31 20 31 32 33 20 31 34 32 22 29 0a 20 20 20  01 123 142").   
2260: 20 28 28 43 48 45 43 4b 29 20 20 20 20 20 20 20   ((CHECK)       
2270: 20 20 20 20 20 22 32 35 35 20 31 30 30 20 35 30       "255 100 50
2280: 22 29 0a 20 20 20 20 28 28 52 45 4d 4f 54 45 48  ").    ((REMOTEH
2290: 4f 53 54 53 54 41 52 54 29 20 20 22 35 30 20 31  OSTSTART)  "50 1
22a0: 33 30 20 31 39 35 22 29 0a 20 20 20 20 28 28 52  30 195").    ((R
22b0: 55 4e 4e 49 4e 47 29 20 20 20 20 20 20 20 20 20  UNNING)         
22c0: 20 22 39 20 31 33 31 20 32 33 32 22 29 0a 20 20   "9 131 232").  
22d0: 20 20 28 28 4b 49 4c 4c 52 45 51 29 20 20 20 20    ((KILLREQ)    
22e0: 20 20 20 20 20 20 22 33 39 20 38 32 20 32 30 36        "39 82 206
22f0: 22 29 0a 20 20 20 20 28 28 4b 49 4c 4c 45 44 29  ").    ((KILLED)
2300: 20 20 20 20 20 20 20 20 20 20 20 22 32 33 34 20             "234 
2310: 31 30 31 20 31 37 22 29 0a 20 20 20 20 28 28 4e  101 17").    ((N
2320: 4f 54 5f 53 54 41 52 54 45 44 29 20 20 20 20 20  OT_STARTED)     
2330: 20 22 32 34 30 20 32 34 30 20 32 34 30 22 29 0a   "240 240 240").
2340: 20 20 20 20 28 65 6c 73 65 20 20 20 20 20 20 20      (else       
2350: 20 20 20 20 20 20 20 20 22 31 39 32 20 31 39 32          "192 192
2360: 20 31 39 32 22 29 29 29 0a 0a 28 64 65 66 69 6e   192")))..(defin
2370: 65 20 28 75 70 64 61 74 65 2d 62 75 74 74 6f 6e  e (update-button
2380: 73 20 75 69 64 61 74 20 6e 75 6d 72 75 6e 73 20  s uidat numruns 
2390: 6e 75 6d 74 65 73 74 73 29 0a 20 20 28 6c 65 74  numtests).  (let
23a0: 2a 20 28 28 72 75 6e 73 20 20 20 20 20 20 20 20  * ((runs        
23b0: 28 69 66 20 28 3e 20 28 6c 65 6e 67 74 68 20 2a  (if (> (length *
23c0: 61 6c 6c 72 75 6e 73 2a 29 20 6e 75 6d 72 75 6e  allruns*) numrun
23d0: 73 29 0a 09 09 09 20 20 28 74 61 6b 65 2d 72 69  s)....  (take-ri
23e0: 67 68 74 20 2a 61 6c 6c 72 75 6e 73 2a 20 6e 75  ght *allruns* nu
23f0: 6d 72 75 6e 73 29 0a 09 09 09 20 20 28 70 61 64  mruns)....  (pad
2400: 2d 6c 69 73 74 20 2a 61 6c 6c 72 75 6e 73 2a 20  -list *allruns* 
2410: 6e 75 6d 72 75 6e 73 29 29 29 0a 09 20 28 6c 66  numruns))).. (lf
2420: 74 63 6f 6c 20 20 20 20 20 20 28 76 65 63 74 6f  tcol      (vecto
2430: 72 2d 72 65 66 20 75 69 64 61 74 20 30 29 29 0a  r-ref uidat 0)).
2440: 09 20 28 74 61 62 6c 65 68 65 61 64 65 72 20 28  . (tableheader (
2450: 76 65 63 74 6f 72 2d 72 65 66 20 75 69 64 61 74  vector-ref uidat
2460: 20 31 29 29 0a 09 20 28 74 61 62 6c 65 20 20 20   1)).. (table   
2470: 20 20 20 20 28 76 65 63 74 6f 72 2d 72 65 66 20      (vector-ref 
2480: 75 69 64 61 74 20 32 29 29 0a 09 20 28 63 6f 6c  uidat 2)).. (col
2490: 6e 20 20 20 20 20 20 20 20 30 29 29 0a 20 20 20  n        0)).   
24a0: 20 28 73 65 74 21 20 2a 61 6c 6c 74 65 73 74 6e   (set! *alltestn
24b0: 61 6d 65 6c 73 74 2a 20 27 28 29 29 0a 20 20 20  amelst* '()).   
24c0: 20 3b 3b 20 63 72 65 61 74 65 20 61 20 63 6f 6e   ;; create a con
24d0: 63 69 73 65 20 6c 69 73 74 20 6f 66 20 74 65 73  cise list of tes
24e0: 74 20 6e 61 6d 65 73 0a 20 20 20 20 28 66 6f 72  t names.    (for
24f0: 2d 65 61 63 68 0a 20 20 20 20 20 28 6c 61 6d 62  -each.     (lamb
2500: 64 61 20 28 72 75 6e 64 61 74 29 0a 20 20 20 20  da (rundat).    
2510: 20 20 20 28 69 66 20 28 76 65 63 74 6f 72 3f 20     (if (vector? 
2520: 72 75 6e 64 61 74 29 0a 09 20 20 20 28 6c 65 74  rundat)..   (let
2530: 2a 20 28 28 74 65 73 74 64 61 74 20 20 20 28 76  * ((testdat   (v
2540: 65 63 74 6f 72 2d 72 65 66 20 72 75 6e 64 61 74  ector-ref rundat
2550: 20 31 29 29 0a 09 09 20 20 28 74 65 73 74 6e 61   1))...  (testna
2560: 6d 65 73 20 28 6d 61 70 20 74 65 73 74 3a 74 65  mes (map test:te
2570: 73 74 2d 67 65 74 2d 66 75 6c 6c 6e 61 6d 65 20  st-get-fullname 
2580: 74 65 73 74 64 61 74 29 29 29 0a 09 20 20 20 20  testdat)))..    
2590: 20 28 66 6f 72 2d 65 61 63 68 20 28 6c 61 6d 62   (for-each (lamb
25a0: 64 61 20 28 74 65 73 74 6e 61 6d 65 29 0a 09 09  da (testname)...
25b0: 09 20 28 69 66 20 28 6e 6f 74 20 28 6d 65 6d 62  . (if (not (memb
25c0: 65 72 20 74 65 73 74 6e 61 6d 65 20 2a 61 6c 6c  er testname *all
25d0: 74 65 73 74 6e 61 6d 65 6c 73 74 2a 29 29 0a 09  testnamelst*))..
25e0: 09 09 20 20 20 20 20 28 62 65 67 69 6e 0a 09 09  ..     (begin...
25f0: 09 20 20 20 20 20 20 20 28 73 65 74 21 20 2a 61  .       (set! *a
2600: 6c 6c 74 65 73 74 6e 61 6d 65 6c 73 74 2a 20 28  lltestnamelst* (
2610: 61 70 70 65 6e 64 20 2a 61 6c 6c 74 65 73 74 6e  append *alltestn
2620: 61 6d 65 6c 73 74 2a 20 28 6c 69 73 74 20 74 65  amelst* (list te
2630: 73 74 6e 61 6d 65 29 29 29 29 29 29 0a 09 09 20  stname))))))... 
2640: 20 20 20 20 20 20 74 65 73 74 6e 61 6d 65 73 29        testnames)
2650: 29 29 29 0a 20 20 20 20 20 72 75 6e 73 29 0a 0a  ))).     runs)..
2660: 20 20 20 20 28 73 65 74 21 20 2a 61 6c 6c 74 65      (set! *allte
2670: 73 74 6e 61 6d 65 6c 73 74 2a 20 28 63 6f 6c 6c  stnamelst* (coll
2680: 61 70 73 65 2d 72 6f 77 73 20 2a 61 6c 6c 74 65  apse-rows *allte
2690: 73 74 6e 61 6d 65 6c 73 74 2a 29 29 20 3b 3b 3b  stnamelst*)) ;;;
26a0: 20 61 72 67 68 2e 20 70 6c 65 61 73 65 20 63 6c   argh. please cl
26b0: 65 61 6e 20 75 70 20 74 68 69 73 20 73 69 6c 6c  ean up this sill
26c0: 79 6e 65 73 73 0a 20 20 20 20 28 73 65 74 21 20  yness.    (set! 
26d0: 2a 61 6c 6c 74 65 73 74 6e 61 6d 65 6c 73 74 2a  *alltestnamelst*
26e0: 20 28 6c 65 74 20 28 28 78 6c 20 28 69 66 20 28   (let ((xl (if (
26f0: 3e 20 28 6c 65 6e 67 74 68 20 2a 61 6c 6c 74 65  > (length *allte
2700: 73 74 6e 61 6d 65 6c 73 74 2a 29 20 2a 73 74 61  stnamelst*) *sta
2710: 72 74 2d 74 65 73 74 2d 6f 66 66 73 65 74 2a 29  rt-test-offset*)
2720: 0a 09 09 09 09 09 20 28 64 72 6f 70 20 2a 61 6c  ...... (drop *al
2730: 6c 74 65 73 74 6e 61 6d 65 6c 73 74 2a 20 2a 73  ltestnamelst* *s
2740: 74 61 72 74 2d 74 65 73 74 2d 6f 66 66 73 65 74  tart-test-offset
2750: 2a 29 0a 09 09 09 09 09 20 27 28 29 29 29 29 0a  *)...... '()))).
2760: 09 09 09 20 20 20 20 20 28 61 70 70 65 6e 64 20  ...     (append 
2770: 78 6c 20 28 6d 61 6b 65 2d 6c 69 73 74 20 28 2d  xl (make-list (-
2780: 20 2a 6e 75 6d 2d 74 65 73 74 73 2a 20 28 6c 65   *num-tests* (le
2790: 6e 67 74 68 20 78 6c 29 29 20 22 22 29 29 29 29  ngth xl)) ""))))
27a0: 0a 20 20 20 20 28 75 70 64 61 74 65 2d 6c 61 62  .    (update-lab
27b0: 65 6c 73 20 75 69 64 61 74 29 0a 20 20 20 20 28  els uidat).    (
27c0: 66 6f 72 2d 65 61 63 68 0a 20 20 20 20 20 28 6c  for-each.     (l
27d0: 61 6d 62 64 61 20 28 72 75 6e 64 61 74 29 0a 20  ambda (rundat). 
27e0: 20 20 20 20 20 20 28 69 66 20 28 6e 6f 74 20 72        (if (not r
27f0: 75 6e 64 61 74 29 20 3b 3b 20 68 61 6e 64 6c 65  undat) ;; handle
2800: 20 70 61 64 64 65 64 20 72 75 6e 73 0a 09 20 20   padded runs..  
2810: 20 3b 3b 20 20 20 20 20 20 20 20 20 20 20 3b 3b   ;;           ;;
2820: 20 69 64 20 72 75 6e 2d 69 64 20 74 65 73 74 6e   id run-id testn
2830: 61 6d 65 20 73 74 61 74 65 20 73 74 61 74 75 73  ame state status
2840: 20 65 76 65 6e 74 2d 74 69 6d 65 20 68 6f 73 74   event-time host
2850: 20 63 70 75 6c 6f 61 64 20 64 69 73 6b 66 72 65   cpuload diskfre
2860: 65 20 75 6e 61 6d 65 20 72 75 6e 64 69 72 20 69  e uname rundir i
2870: 74 65 6d 2d 70 61 74 68 20 72 75 6e 2d 64 75 72  tem-path run-dur
2880: 61 74 69 6f 6e 0a 09 20 20 20 28 73 65 74 21 20  ation..   (set! 
2890: 72 75 6e 64 61 74 20 28 76 65 63 74 6f 72 20 28  rundat (vector (
28a0: 6d 61 6b 65 2d 76 65 63 74 6f 72 20 32 30 20 23  make-vector 20 #
28b0: 66 29 20 27 28 29 20 28 6d 61 70 20 28 6c 61 6d  f) '() (map (lam
28c0: 62 64 61 20 28 78 29 20 22 22 29 20 2a 6b 65 79  bda (x) "") *key
28d0: 73 2a 29 29 29 29 3b 3b 20 33 29 29 29 0a 20 20  s*))));; 3))).  
28e0: 20 20 20 20 20 28 6c 65 74 2a 20 28 28 72 75 6e       (let* ((run
28f0: 20 20 20 20 20 20 28 76 65 63 74 6f 72 2d 72 65        (vector-re
2900: 66 20 72 75 6e 64 61 74 20 30 29 29 0a 09 20 20  f rundat 0))..  
2910: 20 20 20 20 28 74 65 73 74 73 64 61 74 20 28 76      (testsdat (v
2920: 65 63 74 6f 72 2d 72 65 66 20 72 75 6e 64 61 74  ector-ref rundat
2930: 20 31 29 29 0a 09 20 20 20 20 20 20 28 6b 65 79   1))..      (key
2940: 2d 76 61 6c 2d 64 61 74 20 28 76 65 63 74 6f 72  -val-dat (vector
2950: 2d 72 65 66 20 72 75 6e 64 61 74 20 32 29 29 0a  -ref rundat 2)).
2960: 09 20 20 20 20 20 20 28 72 75 6e 2d 69 64 20 20  .      (run-id  
2970: 20 28 64 62 3a 67 65 74 2d 76 61 6c 75 65 2d 62   (db:get-value-b
2980: 79 2d 68 65 61 64 65 72 20 72 75 6e 20 2a 68 65  y-header run *he
2990: 61 64 65 72 2a 20 22 69 64 22 29 29 0a 09 20 20  ader* "id"))..  
29a0: 20 20 20 20 28 6b 65 79 2d 76 61 6c 73 20 28 61      (key-vals (a
29b0: 70 70 65 6e 64 20 6b 65 79 2d 76 61 6c 2d 64 61  ppend key-val-da
29c0: 74 0a 09 09 09 09 28 6c 69 73 74 20 28 6c 65 74  t.....(list (let
29d0: 20 28 28 78 20 28 64 62 3a 67 65 74 2d 76 61 6c   ((x (db:get-val
29e0: 75 65 2d 62 79 2d 68 65 61 64 65 72 20 72 75 6e  ue-by-header run
29f0: 20 2a 68 65 61 64 65 72 2a 20 22 72 75 6e 6e 61   *header* "runna
2a00: 6d 65 22 29 29 29 0a 09 09 09 09 09 28 69 66 20  me")))......(if 
2a10: 78 20 78 20 22 22 29 29 29 29 29 0a 09 20 20 20  x x "")))))..   
2a20: 20 20 20 28 72 75 6e 2d 6b 65 79 20 20 28 73 74     (run-key  (st
2a30: 72 69 6e 67 2d 69 6e 74 65 72 73 70 65 72 73 65  ring-intersperse
2a40: 20 6b 65 79 2d 76 61 6c 73 20 22 5c 6e 22 29 29   key-vals "\n"))
2a50: 29 0a 0a 09 20 3b 3b 20 66 69 6c 6c 20 69 6e 20  )... ;; fill in 
2a60: 74 68 65 20 72 75 6e 20 68 65 61 64 65 72 20 6b  the run header k
2a70: 65 79 20 76 61 6c 75 65 73 0a 09 20 28 6c 65 74  ey values.. (let
2a80: 20 28 28 72 6f 77 6e 20 20 20 20 20 20 30 29 0a   ((rown      0).
2a90: 09 20 20 20 20 20 20 20 28 68 65 61 64 65 72 63  .       (headerc
2aa0: 6f 6c 20 28 76 65 63 74 6f 72 2d 72 65 66 20 74  ol (vector-ref t
2ab0: 61 62 6c 65 68 65 61 64 65 72 20 63 6f 6c 6e 29  ableheader coln)
2ac0: 29 29 0a 09 20 20 20 28 66 6f 72 2d 65 61 63 68  ))..   (for-each
2ad0: 20 28 6c 61 6d 62 64 61 20 28 6b 76 61 6c 29 0a   (lambda (kval).
2ae0: 09 09 20 20 20 20 20 20 20 28 6c 65 74 2a 20 28  ..       (let* (
2af0: 28 6c 61 62 6c 20 20 20 20 20 20 28 76 65 63 74  (labl      (vect
2b00: 6f 72 2d 72 65 66 20 68 65 61 64 65 72 63 6f 6c  or-ref headercol
2b10: 20 72 6f 77 6e 29 29 29 0a 09 09 09 20 28 69 66   rown))).... (if
2b20: 20 28 6e 6f 74 20 28 65 71 75 61 6c 3f 20 6b 76   (not (equal? kv
2b30: 61 6c 20 28 69 75 70 3a 61 74 74 72 69 62 75 74  al (iup:attribut
2b40: 65 20 6c 61 62 6c 20 22 54 49 54 4c 45 22 29 29  e labl "TITLE"))
2b50: 29 0a 09 09 09 20 20 20 20 20 28 69 75 70 3a 61  )....     (iup:a
2b60: 74 74 72 69 62 75 74 65 2d 73 65 74 21 20 28 76  ttribute-set! (v
2b70: 65 63 74 6f 72 2d 72 65 66 20 68 65 61 64 65 72  ector-ref header
2b80: 63 6f 6c 20 72 6f 77 6e 29 20 22 54 49 54 4c 45  col rown) "TITLE
2b90: 22 20 6b 76 61 6c 29 29 0a 09 09 09 20 28 73 65  " kval)).... (se
2ba0: 74 21 20 72 6f 77 6e 20 28 2b 20 72 6f 77 6e 20  t! rown (+ rown 
2bb0: 31 29 29 29 29 0a 09 09 20 20 20 20 20 6b 65 79  1))))...     key
2bc0: 2d 76 61 6c 73 29 29 0a 0a 09 20 3b 3b 20 46 6f  -vals))... ;; Fo
2bd0: 72 20 74 68 69 73 20 72 75 6e 20 6e 6f 77 20 66  r this run now f
2be0: 69 6c 6c 20 69 6e 20 74 68 65 20 62 75 74 74 6f  ill in the butto
2bf0: 6e 73 20 66 6f 72 20 65 61 63 68 20 74 65 73 74  ns for each test
2c00: 0a 09 20 28 6c 65 74 20 28 28 72 6f 77 6e 20 30  .. (let ((rown 0
2c10: 29 0a 09 20 20 20 20 20 20 20 28 63 6f 6c 75 6d  )..       (colum
2c20: 6e 64 61 74 20 20 28 76 65 63 74 6f 72 2d 72 65  ndat  (vector-re
2c30: 66 20 74 61 62 6c 65 20 63 6f 6c 6e 29 29 29 0a  f table coln))).
2c40: 09 20 20 20 28 66 6f 72 2d 65 61 63 68 0a 09 20  .   (for-each.. 
2c50: 20 20 20 28 6c 61 6d 62 64 61 20 28 74 65 73 74     (lambda (test
2c60: 6e 61 6d 65 29 0a 09 20 20 20 20 20 20 28 6c 65  name)..      (le
2c70: 74 20 28 28 62 75 74 74 6f 6e 64 61 74 20 20 28  t ((buttondat  (
2c80: 68 61 73 68 2d 74 61 62 6c 65 2d 72 65 66 2f 64  hash-table-ref/d
2c90: 65 66 61 75 6c 74 20 2a 62 75 74 74 6f 6e 64 61  efault *buttonda
2ca0: 74 2a 20 28 6d 6b 73 74 72 20 63 6f 6c 6e 20 72  t* (mkstr coln r
2cb0: 6f 77 6e 29 20 23 66 29 29 29 0a 09 09 28 69 66  own) #f)))...(if
2cc0: 20 62 75 74 74 6f 6e 64 61 74 0a 09 09 20 20 20   buttondat...   
2cd0: 20 28 6c 65 74 2a 20 28 28 74 65 73 74 20 20 20   (let* ((test   
2ce0: 20 20 20 20 28 6c 65 74 20 28 28 6d 61 74 63 68      (let ((match
2cf0: 69 6e 67 20 28 66 69 6c 74 65 72 20 0a 09 09 09  ing (filter ....
2d00: 09 09 09 09 28 6c 61 6d 62 64 61 20 28 78 29 28  ....(lambda (x)(
2d10: 65 71 75 61 6c 3f 20 28 74 65 73 74 3a 74 65 73  equal? (test:tes
2d20: 74 2d 67 65 74 2d 66 75 6c 6c 6e 61 6d 65 20 78  t-get-fullname x
2d30: 29 20 74 65 73 74 6e 61 6d 65 29 29 0a 09 09 09  ) testname))....
2d40: 09 09 09 09 74 65 73 74 73 64 61 74 29 29 29 0a  ....testsdat))).
2d50: 09 09 09 09 09 20 28 69 66 20 28 6e 75 6c 6c 3f  ..... (if (null?
2d60: 20 6d 61 74 63 68 69 6e 67 29 0a 09 09 09 09 09   matching)......
2d70: 20 20 20 20 20 28 76 65 63 74 6f 72 20 2d 31 20       (vector -1 
2d80: 2d 31 20 22 22 20 22 22 20 22 22 20 30 20 22 22  -1 "" "" "" 0 ""
2d90: 20 22 22 20 30 20 22 22 20 22 22 20 22 22 20 30   "" 0 "" "" "" 0
2da0: 20 22 22 20 22 22 29 0a 09 09 09 09 09 20 20 20   "" "")......   
2db0: 20 20 28 63 61 72 20 6d 61 74 63 68 69 6e 67 29    (car matching)
2dc0: 29 29 29 0a 09 09 09 20 20 20 28 74 65 73 74 6e  )))....   (testn
2dd0: 61 6d 65 20 20 20 28 64 62 3a 74 65 73 74 2d 67  ame   (db:test-g
2de0: 65 74 2d 74 65 73 74 6e 61 6d 65 20 20 74 65 73  et-testname  tes
2df0: 74 29 29 0a 09 09 09 20 20 20 28 69 74 65 6d 70  t))....   (itemp
2e00: 61 74 68 20 20 20 28 64 62 3a 74 65 73 74 2d 67  ath   (db:test-g
2e10: 65 74 2d 69 74 65 6d 2d 70 61 74 68 20 74 65 73  et-item-path tes
2e20: 74 29 29 0a 09 09 09 20 20 20 28 74 65 73 74 66  t))....   (testf
2e30: 75 6c 6c 6e 61 6d 65 20 28 74 65 73 74 3a 74 65  ullname (test:te
2e40: 73 74 2d 67 65 74 2d 66 75 6c 6c 6e 61 6d 65 20  st-get-fullname 
2e50: 74 65 73 74 29 29 0a 09 09 09 20 20 20 28 74 65  test))....   (te
2e60: 73 74 73 74 61 74 75 73 20 28 64 62 3a 74 65 73  ststatus (db:tes
2e70: 74 2d 67 65 74 2d 73 74 61 74 75 73 20 20 20 74  t-get-status   t
2e80: 65 73 74 29 29 0a 09 09 09 20 20 20 28 74 65 73  est))....   (tes
2e90: 74 73 74 61 74 65 20 20 28 64 62 3a 74 65 73 74  tstate  (db:test
2ea0: 2d 67 65 74 2d 73 74 61 74 65 20 20 20 20 74 65  -get-state    te
2eb0: 73 74 29 29 0a 09 09 09 20 20 20 28 74 65 73 74  st))....   (test
2ec0: 73 74 61 72 74 20 20 28 64 62 3a 74 65 73 74 2d  start  (db:test-
2ed0: 67 65 74 2d 65 76 65 6e 74 5f 74 69 6d 65 20 74  get-event_time t
2ee0: 65 73 74 29 29 0a 09 09 09 20 20 20 28 72 75 6e  est))....   (run
2ef0: 74 69 6d 65 20 20 20 20 28 64 62 3a 74 65 73 74  time    (db:test
2f00: 2d 67 65 74 2d 72 75 6e 5f 64 75 72 61 74 69 6f  -get-run_duratio
2f10: 6e 20 74 65 73 74 29 29 0a 09 09 09 20 20 20 28  n test))....   (
2f20: 62 75 74 74 6f 6e 74 78 74 20 20 28 69 66 20 28  buttontxt  (if (
2f30: 65 71 75 61 6c 3f 20 74 65 73 74 73 74 61 74 65  equal? teststate
2f40: 20 22 43 4f 4d 50 4c 45 54 45 44 22 29 20 74 65   "COMPLETED") te
2f50: 73 74 73 74 61 74 75 73 20 74 65 73 74 73 74 61  ststatus teststa
2f60: 74 65 29 29 0a 09 09 09 20 20 20 28 62 75 74 74  te))....   (butt
2f70: 6f 6e 20 20 20 20 20 28 76 65 63 74 6f 72 2d 72  on     (vector-r
2f80: 65 66 20 63 6f 6c 75 6d 6e 64 61 74 20 72 6f 77  ef columndat row
2f90: 6e 29 29 0a 09 09 09 20 20 20 28 63 6f 6c 6f 72  n))....   (color
2fa0: 20 20 20 20 20 20 28 67 65 74 2d 63 6f 6c 6f 72        (get-color
2fb0: 2d 66 6f 72 2d 73 74 61 74 65 2d 73 74 61 74 75  -for-state-statu
2fc0: 73 20 74 65 73 74 73 74 61 74 65 20 74 65 73 74  s teststate test
2fd0: 73 74 61 74 75 73 29 29 0a 09 09 09 20 20 20 28  status))....   (
2fe0: 63 75 72 72 2d 63 6f 6c 6f 72 20 28 76 65 63 74  curr-color (vect
2ff0: 6f 72 2d 72 65 66 20 62 75 74 74 6f 6e 64 61 74  or-ref buttondat
3000: 20 31 29 29 20 3b 3b 20 28 69 75 70 3a 61 74 74   1)) ;; (iup:att
3010: 72 69 62 75 74 65 20 62 75 74 74 6f 6e 20 22 42  ribute button "B
3020: 47 43 4f 4c 4f 52 22 29 29 0a 09 09 09 20 20 20  GCOLOR"))....   
3030: 28 63 75 72 72 2d 74 69 74 6c 65 20 28 76 65 63  (curr-title (vec
3040: 74 6f 72 2d 72 65 66 20 62 75 74 74 6f 6e 64 61  tor-ref buttonda
3050: 74 20 32 29 29 29 20 3b 3b 20 28 69 75 70 3a 61  t 2))) ;; (iup:a
3060: 74 74 72 69 62 75 74 65 20 62 75 74 74 6f 6e 20  ttribute button 
3070: 22 54 49 54 4c 45 22 29 29 29 0a 09 09 20 20 20  "TITLE")))...   
3080: 20 20 20 28 69 66 20 28 6e 6f 74 20 28 65 71 75     (if (not (equ
3090: 61 6c 3f 20 63 75 72 72 2d 63 6f 6c 6f 72 20 63  al? curr-color c
30a0: 6f 6c 6f 72 29 29 0a 09 09 09 20 20 28 69 75 70  olor))....  (iup
30b0: 3a 61 74 74 72 69 62 75 74 65 2d 73 65 74 21 20  :attribute-set! 
30c0: 62 75 74 74 6f 6e 20 22 42 47 43 4f 4c 4f 52 22  button "BGCOLOR"
30d0: 20 63 6f 6c 6f 72 29 29 0a 09 09 20 20 20 20 20   color))...     
30e0: 20 28 69 66 20 28 6e 6f 74 20 28 65 71 75 61 6c   (if (not (equal
30f0: 3f 20 63 75 72 72 2d 74 69 74 6c 65 20 62 75 74  ? curr-title but
3100: 74 6f 6e 74 78 74 29 29 0a 09 09 09 20 20 28 69  tontxt))....  (i
3110: 75 70 3a 61 74 74 72 69 62 75 74 65 2d 73 65 74  up:attribute-set
3120: 21 20 62 75 74 74 6f 6e 20 22 54 49 54 4c 45 22  ! button "TITLE"
3130: 20 20 20 62 75 74 74 6f 6e 74 78 74 29 29 0a 09     buttontxt))..
3140: 09 20 20 20 20 20 20 28 76 65 63 74 6f 72 2d 73  .      (vector-s
3150: 65 74 21 20 62 75 74 74 6f 6e 64 61 74 20 30 20  et! buttondat 0 
3160: 72 75 6e 2d 69 64 29 0a 09 09 20 20 20 20 20 20  run-id)...      
3170: 28 76 65 63 74 6f 72 2d 73 65 74 21 20 62 75 74  (vector-set! but
3180: 74 6f 6e 64 61 74 20 31 20 63 6f 6c 6f 72 29 0a  tondat 1 color).
3190: 09 09 20 20 20 20 20 20 28 76 65 63 74 6f 72 2d  ..      (vector-
31a0: 73 65 74 21 20 62 75 74 74 6f 6e 64 61 74 20 32  set! buttondat 2
31b0: 20 62 75 74 74 6f 6e 74 78 74 29 0a 09 09 20 20   buttontxt)...  
31c0: 20 20 20 20 28 76 65 63 74 6f 72 2d 73 65 74 21      (vector-set!
31d0: 20 62 75 74 74 6f 6e 64 61 74 20 33 20 74 65 73   buttondat 3 tes
31e0: 74 29 0a 09 09 20 20 20 20 20 20 28 76 65 63 74  t)...      (vect
31f0: 6f 72 2d 73 65 74 21 20 62 75 74 74 6f 6e 64 61  or-set! buttonda
3200: 74 20 34 20 72 75 6e 2d 6b 65 79 29 29 29 0a 09  t 4 run-key)))..
3210: 09 28 73 65 74 21 20 72 6f 77 6e 20 28 2b 20 72  .(set! rown (+ r
3220: 6f 77 6e 20 31 29 29 29 29 0a 09 20 20 20 20 2a  own 1))))..    *
3230: 61 6c 6c 74 65 73 74 6e 61 6d 65 6c 73 74 2a 29  alltestnamelst*)
3240: 29 0a 09 20 28 73 65 74 21 20 63 6f 6c 6e 20 28  ).. (set! coln (
3250: 2b 20 63 6f 6c 6e 20 31 29 29 29 29 0a 20 20 20  + coln 1)))).   
3260: 20 20 72 75 6e 73 29 29 29 0a 0a 28 64 65 66 69    runs)))..(defi
3270: 6e 65 20 28 6d 6b 73 74 72 20 2e 20 78 29 0a 20  ne (mkstr . x). 
3280: 20 28 73 74 72 69 6e 67 2d 69 6e 74 65 72 73 70   (string-intersp
3290: 65 72 73 65 20 28 6d 61 70 20 63 6f 6e 63 20 78  erse (map conc x
32a0: 29 20 22 2c 22 29 29 0a 0a 28 64 65 66 69 6e 65  ) ","))..(define
32b0: 20 28 75 70 64 61 74 65 2d 73 65 61 72 63 68 20   (update-search 
32c0: 78 20 76 61 6c 29 0a 20 20 3b 3b 20 28 70 72 69  x val).  ;; (pri
32d0: 6e 74 20 22 53 65 74 74 69 6e 67 20 73 65 61 72  nt "Setting sear
32e0: 63 68 20 66 6f 72 20 22 20 78 20 22 20 74 6f 20  ch for " x " to 
32f0: 22 20 76 61 6c 29 0a 20 20 28 68 61 73 68 2d 74  " val).  (hash-t
3300: 61 62 6c 65 2d 73 65 74 21 20 2a 73 65 61 72 63  able-set! *searc
3310: 68 70 61 74 74 73 2a 20 78 20 76 61 6c 29 29 0a  hpatts* x val)).
3320: 0a 28 64 65 66 69 6e 65 20 28 6d 61 6b 65 2d 64  .(define (make-d
3330: 61 73 68 62 6f 61 72 64 2d 62 75 74 74 6f 6e 73  ashboard-buttons
3340: 20 6e 72 75 6e 73 20 6e 74 65 73 74 73 20 6b 65   nruns ntests ke
3350: 79 6e 61 6d 65 73 29 0a 20 20 28 6c 65 74 2a 20  ynames).  (let* 
3360: 28 28 6e 6b 65 79 73 20 20 20 28 6c 65 6e 67 74  ((nkeys   (lengt
3370: 68 20 6b 65 79 6e 61 6d 65 73 29 29 0a 09 20 28  h keynames)).. (
3380: 72 75 6e 73 76 65 63 20 28 6d 61 6b 65 2d 76 65  runsvec (make-ve
3390: 63 74 6f 72 20 6e 72 75 6e 73 29 29 0a 09 20 28  ctor nruns)).. (
33a0: 68 65 61 64 65 72 20 20 28 6d 61 6b 65 2d 76 65  header  (make-ve
33b0: 63 74 6f 72 20 6e 72 75 6e 73 29 29 0a 09 20 28  ctor nruns)).. (
33c0: 6c 66 74 63 6f 6c 20 20 28 6d 61 6b 65 2d 76 65  lftcol  (make-ve
33d0: 63 74 6f 72 20 6e 74 65 73 74 73 29 29 0a 09 20  ctor ntests)).. 
33e0: 28 63 6f 6e 74 72 6f 6c 73 20 27 28 29 29 0a 09  (controls '())..
33f0: 20 28 6c 66 74 6c 73 74 20 20 27 28 29 29 0a 09   (lftlst  '())..
3400: 20 28 68 64 72 6c 73 74 20 20 27 28 29 29 0a 09   (hdrlst  '())..
3410: 20 28 62 64 79 6c 73 74 20 20 27 28 29 29 0a 09   (bdylst  '())..
3420: 20 28 72 65 73 75 6c 74 20 20 27 28 29 29 0a 09   (result  '())..
3430: 20 28 69 20 20 20 20 20 20 20 30 29 29 0a 20 20   (i       0)).  
3440: 20 20 3b 3b 20 63 6f 6e 74 72 6f 6c 73 20 28 61    ;; controls (a
3450: 6c 6f 6e 67 20 62 6f 74 74 6f 6d 29 0a 20 20 20  long bottom).   
3460: 20 28 73 65 74 21 20 63 6f 6e 74 72 6f 6c 73 0a   (set! controls.
3470: 09 20 20 28 69 75 70 3a 68 62 6f 78 0a 09 20 20  .  (iup:hbox..  
3480: 20 28 69 75 70 3a 74 65 78 74 62 6f 78 20 23 3a   (iup:textbox #:
3490: 73 69 7a 65 20 22 36 30 78 31 35 22 20 23 3a 66  size "60x15" #:f
34a0: 6f 6e 74 73 69 7a 65 20 22 31 30 22 20 23 3a 76  ontsize "10" #:v
34b0: 61 6c 75 65 20 22 25 22 0a 09 09 09 23 3a 61 63  alue "%"....#:ac
34c0: 74 69 6f 6e 20 28 6c 61 6d 62 64 61 20 28 6f 62  tion (lambda (ob
34d0: 6a 20 75 6e 6b 20 76 61 6c 29 0a 09 09 09 09 20  j unk val)..... 
34e0: 20 20 28 75 70 64 61 74 65 2d 73 65 61 72 63 68    (update-search
34f0: 20 22 74 65 73 74 2d 6e 61 6d 65 22 20 76 61 6c   "test-name" val
3500: 29 29 29 0a 09 20 20 20 28 69 75 70 3a 74 65 78  )))..   (iup:tex
3510: 74 62 6f 78 20 23 3a 73 69 7a 65 20 22 36 30 78  tbox #:size "60x
3520: 31 35 22 20 23 3a 66 6f 6e 74 73 69 7a 65 20 22  15" #:fontsize "
3530: 31 30 22 20 23 3a 76 61 6c 75 65 20 22 25 22 0a  10" #:value "%".
3540: 09 09 09 23 3a 61 63 74 69 6f 6e 20 28 6c 61 6d  ...#:action (lam
3550: 62 64 61 20 28 6f 62 6a 20 75 6e 6b 20 76 61 6c  bda (obj unk val
3560: 29 0a 09 09 09 09 20 20 20 28 75 70 64 61 74 65  ).....   (update
3570: 2d 73 65 61 72 63 68 20 22 69 74 65 6d 2d 6e 61  -search "item-na
3580: 6d 65 22 20 76 61 6c 29 29 29 0a 09 20 20 20 28  me" val)))..   (
3590: 69 75 70 3a 62 75 74 74 6f 6e 20 22 51 75 69 74  iup:button "Quit
35a0: 22 20 23 3a 61 63 74 69 6f 6e 20 28 6c 61 6d 62  " #:action (lamb
35b0: 64 61 20 28 6f 62 6a 29 28 73 71 6c 69 74 65 33  da (obj)(sqlite3
35c0: 3a 66 69 6e 61 6c 69 7a 65 21 20 2a 64 62 2a 29  :finalize! *db*)
35d0: 28 65 78 69 74 29 29 29 0a 09 20 20 20 28 69 75  (exit)))..   (iu
35e0: 70 3a 62 75 74 74 6f 6e 20 22 3c 2d 20 20 4c 65  p:button "<-  Le
35f0: 66 74 22 20 23 3a 61 63 74 69 6f 6e 20 28 6c 61  ft" #:action (la
3600: 6d 62 64 61 20 28 6f 62 6a 29 28 73 65 74 21 20  mbda (obj)(set! 
3610: 2a 73 74 61 72 74 2d 72 75 6e 2d 6f 66 66 73 65  *start-run-offse
3620: 74 2a 20 20 28 2b 20 2a 73 74 61 72 74 2d 72 75  t*  (+ *start-ru
3630: 6e 2d 6f 66 66 73 65 74 2a 20 31 29 29 29 29 0a  n-offset* 1)))).
3640: 09 20 20 20 28 69 75 70 3a 62 75 74 74 6f 6e 20  .   (iup:button 
3650: 22 55 70 20 20 20 20 20 5e 22 20 23 3a 61 63 74  "Up     ^" #:act
3660: 69 6f 6e 20 28 6c 61 6d 62 64 61 20 28 6f 62 6a  ion (lambda (obj
3670: 29 28 73 65 74 21 20 2a 73 74 61 72 74 2d 74 65  )(set! *start-te
3680: 73 74 2d 6f 66 66 73 65 74 2a 20 28 69 66 20 28  st-offset* (if (
3690: 3e 20 2a 73 74 61 72 74 2d 74 65 73 74 2d 6f 66  > *start-test-of
36a0: 66 73 65 74 2a 20 30 29 28 2d 20 2a 73 74 61 72  fset* 0)(- *star
36b0: 74 2d 74 65 73 74 2d 6f 66 66 73 65 74 2a 20 31  t-test-offset* 1
36c0: 29 20 30 29 29 29 29 0a 09 20 20 20 28 69 75 70  ) 0))))..   (iup
36d0: 3a 62 75 74 74 6f 6e 20 22 44 6f 77 6e 20 20 20  :button "Down   
36e0: 76 22 20 23 3a 61 63 74 69 6f 6e 20 28 6c 61 6d  v" #:action (lam
36f0: 62 64 61 20 28 6f 62 6a 29 28 73 65 74 21 20 2a  bda (obj)(set! *
3700: 73 74 61 72 74 2d 74 65 73 74 2d 6f 66 66 73 65  start-test-offse
3710: 74 2a 20 28 69 66 20 28 3e 3d 20 2a 73 74 61 72  t* (if (>= *star
3720: 74 2d 74 65 73 74 2d 6f 66 66 73 65 74 2a 20 28  t-test-offset* (
3730: 6c 65 6e 67 74 68 20 2a 61 6c 6c 74 65 73 74 6e  length *alltestn
3740: 61 6d 65 6c 73 74 2a 29 29 28 6c 65 6e 67 74 68  amelst*))(length
3750: 20 2a 61 6c 6c 74 65 73 74 6e 61 6d 65 6c 73 74   *alltestnamelst
3760: 2a 29 28 2b 20 2a 73 74 61 72 74 2d 74 65 73 74  *)(+ *start-test
3770: 2d 6f 66 66 73 65 74 2a 20 31 29 29 29 29 29 0a  -offset* 1))))).
3780: 09 20 20 20 28 69 75 70 3a 62 75 74 74 6f 6e 20  .   (iup:button 
3790: 22 52 69 67 68 74 20 2d 3e 22 20 23 3a 61 63 74  "Right ->" #:act
37a0: 69 6f 6e 20 28 6c 61 6d 62 64 61 20 28 6f 62 6a  ion (lambda (obj
37b0: 29 28 73 65 74 21 20 2a 73 74 61 72 74 2d 72 75  )(set! *start-ru
37c0: 6e 2d 6f 66 66 73 65 74 2a 20 20 28 69 66 20 28  n-offset*  (if (
37d0: 3e 20 2a 73 74 61 72 74 2d 72 75 6e 2d 6f 66 66  > *start-run-off
37e0: 73 65 74 2a 20 30 29 28 2d 20 2a 73 74 61 72 74  set* 0)(- *start
37f0: 2d 72 75 6e 2d 6f 66 66 73 65 74 2a 20 31 29 20  -run-offset* 1) 
3800: 30 29 29 29 29 0a 09 20 20 20 3b 28 69 75 70 3a  0))))..   ;(iup:
3810: 62 75 74 74 6f 6e 20 22 69 6e 63 20 72 6f 77 73  button "inc rows
3820: 22 20 23 3a 61 63 74 69 6f 6e 20 28 6c 61 6d 62  " #:action (lamb
3830: 64 61 20 28 6f 62 6a 29 28 73 65 74 21 20 2a 6e  da (obj)(set! *n
3840: 75 6d 2d 74 65 73 74 73 2a 20 28 2b 20 2a 6e 75  um-tests* (+ *nu
3850: 6d 2d 74 65 73 74 73 2a 20 31 29 29 29 29 0a 09  m-tests* 1))))..
3860: 20 20 20 3b 28 69 75 70 3a 62 75 74 74 6f 6e 20     ;(iup:button 
3870: 22 64 65 63 20 72 6f 77 73 22 20 23 3a 61 63 74  "dec rows" #:act
3880: 69 6f 6e 20 28 6c 61 6d 62 64 61 20 28 6f 62 6a  ion (lambda (obj
3890: 29 28 73 65 74 21 20 2a 6e 75 6d 2d 74 65 73 74  )(set! *num-test
38a0: 73 2a 20 28 69 66 20 28 3e 20 2a 6e 75 6d 2d 74  s* (if (> *num-t
38b0: 65 73 74 73 2a 20 30 29 28 2d 20 2a 6e 75 6d 2d  ests* 0)(- *num-
38c0: 74 65 73 74 73 2a 20 31 29 20 30 29 29 29 29 0a  tests* 1) 0)))).
38d0: 09 20 20 20 29 0a 09 20 20 29 0a 20 20 20 20 0a  .   )..  ).    .
38e0: 20 20 20 20 3b 3b 20 63 72 65 61 74 65 20 74 68      ;; create th
38f0: 65 20 6c 65 66 74 20 6d 6f 73 74 20 63 6f 6c 75  e left most colu
3900: 6d 6e 20 66 6f 72 20 74 68 65 20 72 75 6e 20 6b  mn for the run k
3910: 65 79 20 6e 61 6d 65 73 20 61 6e 64 20 74 68 65  ey names and the
3920: 20 74 65 73 74 20 6e 61 6d 65 73 20 0a 20 20 20   test names .   
3930: 20 28 73 65 74 21 20 6c 66 74 6c 73 74 20 28 6c   (set! lftlst (l
3940: 69 73 74 20 28 61 70 70 6c 79 20 69 75 70 3a 76  ist (apply iup:v
3950: 62 6f 78 20 0a 09 09 09 20 20 20 20 20 20 28 6d  box ....      (m
3960: 61 70 20 28 6c 61 6d 62 64 61 20 28 78 29 09 09  ap (lambda (x)..
3970: 0a 09 09 09 09 20 20 20 20 20 28 6c 65 74 20 28  .....     (let (
3980: 28 72 65 73 20 28 69 75 70 3a 68 62 6f 78 0a 09  (res (iup:hbox..
3990: 09 09 09 09 09 20 28 69 75 70 3a 6c 61 62 65 6c  ..... (iup:label
39a0: 20 78 20 23 3a 73 69 7a 65 20 22 34 30 78 31 35   x #:size "40x15
39b0: 22 20 23 3a 66 6f 6e 74 73 69 7a 65 20 22 31 30  " #:fontsize "10
39c0: 22 29 20 3b 3b 20 20 23 3a 65 78 70 61 6e 64 20  ") ;;  #:expand 
39d0: 22 48 4f 52 49 5a 4f 4e 54 41 4c 22 29 0a 09 09  "HORIZONTAL")...
39e0: 09 09 09 09 20 28 69 75 70 3a 74 65 78 74 62 6f  .... (iup:textbo
39f0: 78 20 23 3a 73 69 7a 65 20 22 36 30 78 31 35 22  x #:size "60x15"
3a00: 20 23 3a 66 6f 6e 74 73 69 7a 65 20 22 31 30 22   #:fontsize "10"
3a10: 20 23 3a 76 61 6c 75 65 20 22 25 22 20 3b 3b 20   #:value "%" ;; 
3a20: 23 3a 65 78 70 61 6e 64 20 22 48 4f 52 49 5a 4f  #:expand "HORIZO
3a30: 4e 54 41 4c 22 0a 09 09 09 09 09 09 09 20 20 20  NTAL"........   
3a40: 20 20 20 23 3a 61 63 74 69 6f 6e 20 28 6c 61 6d     #:action (lam
3a50: 62 64 61 20 28 6f 62 6a 20 75 6e 6b 20 76 61 6c  bda (obj unk val
3a60: 29 0a 09 09 09 09 09 09 09 09 09 20 28 75 70 64  ).......... (upd
3a70: 61 74 65 2d 73 65 61 72 63 68 20 78 20 76 61 6c  ate-search x val
3a80: 29 29 29 29 29 29 0a 09 09 09 09 20 20 20 20 20  )))))).....     
3a90: 20 20 28 73 65 74 21 20 69 20 28 2b 20 69 20 31    (set! i (+ i 1
3aa0: 29 29 0a 09 09 09 09 20 20 20 20 20 20 20 72 65  )).....       re
3ab0: 73 29 29 0a 09 09 09 09 20 20 20 6b 65 79 6e 61  s)).....   keyna
3ac0: 6d 65 73 29 29 29 29 0a 20 20 20 20 28 6c 65 74  mes)))).    (let
3ad0: 20 6c 6f 6f 70 20 28 28 74 65 73 74 6e 75 6d 20   loop ((testnum 
3ae0: 20 30 29 0a 09 20 20 20 20 20 20 20 28 72 65 73   0)..       (res
3af0: 20 20 20 20 20 20 27 28 29 29 29 0a 20 20 20 20        '())).    
3b00: 20 20 28 63 6f 6e 64 0a 20 20 20 20 20 20 20 28    (cond.       (
3b10: 28 3e 3d 20 74 65 73 74 6e 75 6d 20 6e 74 65 73  (>= testnum ntes
3b20: 74 73 29 0a 09 3b 3b 20 6e 6f 77 20 6c 66 74 6c  ts)..;; now lftl
3b30: 73 74 20 77 69 6c 6c 20 62 65 20 61 6e 20 68 62  st will be an hb
3b40: 6f 78 20 77 69 74 68 20 74 68 65 20 74 65 73 74  ox with the test
3b50: 20 6b 65 79 73 20 61 6e 64 20 74 68 65 20 74 65   keys and the te
3b60: 73 74 20 6e 61 6d 65 20 6c 61 62 65 6c 73 0a 09  st name labels..
3b70: 28 73 65 74 21 20 6c 66 74 6c 73 74 20 28 61 70  (set! lftlst (ap
3b80: 70 65 6e 64 20 6c 66 74 6c 73 74 20 28 6c 69 73  pend lftlst (lis
3b90: 74 20 28 61 70 70 6c 79 20 69 75 70 3a 76 62 6f  t (apply iup:vbo
3ba0: 78 20 28 72 65 76 65 72 73 65 20 72 65 73 29 29  x (reverse res))
3bb0: 29 29 29 29 0a 20 20 20 20 20 20 20 28 65 6c 73  )))).       (els
3bc0: 65 0a 09 28 6c 65 74 20 28 28 6c 61 62 6c 20 20  e..(let ((labl  
3bd0: 28 69 75 70 3a 62 75 74 74 6f 6e 20 22 22 20 0a  (iup:button "" .
3be0: 09 09 09 09 20 23 3a 66 6c 61 74 20 22 59 45 53  .... #:flat "YES
3bf0: 22 20 0a 09 09 09 09 20 3b 20 23 3a 69 6d 61 67  " ..... ; #:imag
3c00: 65 20 69 6d 67 31 0a 09 09 09 09 20 3b 20 23 3a  e img1..... ; #:
3c10: 69 6d 70 72 65 73 73 20 69 6d 67 32 0a 09 09 09  impress img2....
3c20: 09 20 23 3a 73 69 7a 65 20 22 31 30 30 78 31 35  . #:size "100x15
3c30: 22 0a 09 09 09 09 20 23 3a 66 6f 6e 74 73 69 7a  "..... #:fontsiz
3c40: 65 20 22 31 30 22 0a 09 09 09 09 20 23 3a 61 63  e "10"..... #:ac
3c50: 74 69 6f 6e 20 28 6c 61 6d 62 64 61 20 28 6f 62  tion (lambda (ob
3c60: 6a 29 0a 09 09 09 09 09 20 20 20 20 20 20 28 74  j)......      (t
3c70: 6f 67 67 6c 65 2d 68 69 64 65 20 74 65 73 74 6e  oggle-hide testn
3c80: 75 6d 29 29 29 29 29 20 3b 3b 20 28 69 75 70 3a  um))))) ;; (iup:
3c90: 61 74 74 72 69 62 75 74 65 20 6f 62 6a 20 22 54  attribute obj "T
3ca0: 49 54 4c 45 22 29 29 29 29 0a 09 20 20 28 76 65  ITLE"))))..  (ve
3cb0: 63 74 6f 72 2d 73 65 74 21 20 6c 66 74 63 6f 6c  ctor-set! lftcol
3cc0: 20 74 65 73 74 6e 75 6d 20 6c 61 62 6c 29 0a 09   testnum labl)..
3cd0: 20 20 28 6c 6f 6f 70 20 28 2b 20 74 65 73 74 6e    (loop (+ testn
3ce0: 75 6d 20 31 29 28 63 6f 6e 73 20 6c 61 62 6c 20  um 1)(cons labl 
3cf0: 72 65 73 29 29 29 29 29 29 0a 20 20 20 20 3b 3b  res)))))).    ;;
3d00: 20 0a 20 20 20 20 28 6c 65 74 20 6c 6f 6f 70 20   .    (let loop 
3d10: 28 28 72 75 6e 6e 75 6d 20 20 30 29 0a 09 20 20  ((runnum  0)..  
3d20: 20 20 20 20 20 28 6b 65 79 6e 75 6d 20 20 30 29       (keynum  0)
3d30: 0a 09 20 20 20 20 20 20 20 28 6b 65 79 76 65 63  ..       (keyvec
3d40: 20 20 28 6d 61 6b 65 2d 76 65 63 74 6f 72 20 6e    (make-vector n
3d50: 6b 65 79 73 29 29 0a 09 20 20 20 20 20 20 20 28  keys))..       (
3d60: 72 65 73 20 20 20 20 27 28 29 29 29 0a 20 20 20  res    '())).   
3d70: 20 20 20 28 63 6f 6e 64 20 3b 3b 20 6e 62 2f 2f     (cond ;; nb//
3d80: 20 6e 6f 20 65 6c 73 65 20 66 6f 72 20 74 68 69   no else for thi
3d90: 73 20 61 70 70 72 6f 61 63 68 2e 0a 20 20 20 20  s approach..    
3da0: 20 20 20 28 28 3e 3d 20 72 75 6e 6e 75 6d 20 6e     ((>= runnum n
3db0: 72 75 6e 73 29 20 23 66 29 0a 20 20 20 20 20 20  runs) #f).      
3dc0: 20 28 28 3e 3d 20 6b 65 79 6e 75 6d 20 6e 6b 65   ((>= keynum nke
3dd0: 79 73 29 20 0a 09 28 76 65 63 74 6f 72 2d 73 65  ys) ..(vector-se
3de0: 74 21 20 68 65 61 64 65 72 20 72 75 6e 6e 75 6d  t! header runnum
3df0: 20 6b 65 79 76 65 63 29 0a 09 28 73 65 74 21 20   keyvec)..(set! 
3e00: 68 64 72 6c 73 74 20 28 63 6f 6e 73 20 28 61 70  hdrlst (cons (ap
3e10: 70 6c 79 20 69 75 70 3a 76 62 6f 78 20 28 72 65  ply iup:vbox (re
3e20: 76 65 72 73 65 20 72 65 73 29 29 20 68 64 72 6c  verse res)) hdrl
3e30: 73 74 29 29 0a 09 28 6c 6f 6f 70 20 28 2b 20 72  st))..(loop (+ r
3e40: 75 6e 6e 75 6d 20 31 29 20 30 20 28 6d 61 6b 65  unnum 1) 0 (make
3e50: 2d 76 65 63 74 6f 72 20 6e 6b 65 79 73 29 20 27  -vector nkeys) '
3e60: 28 29 29 29 0a 20 20 20 20 20 20 20 28 65 6c 73  ())).       (els
3e70: 65 0a 09 28 6c 65 74 20 28 28 6c 61 62 6c 20 20  e..(let ((labl  
3e80: 28 69 75 70 3a 6c 61 62 65 6c 20 22 22 20 23 3a  (iup:label "" #:
3e90: 73 69 7a 65 20 22 36 30 78 31 35 22 20 23 3a 66  size "60x15" #:f
3ea0: 6f 6e 74 73 69 7a 65 20 22 31 30 22 29 29 29 20  ontsize "10"))) 
3eb0: 3b 3b 20 23 3a 65 78 70 61 6e 64 20 22 48 4f 52  ;; #:expand "HOR
3ec0: 49 5a 4f 4e 54 41 4c 22 0a 09 20 20 28 76 65 63  IZONTAL"..  (vec
3ed0: 74 6f 72 2d 73 65 74 21 20 6b 65 79 76 65 63 20  tor-set! keyvec 
3ee0: 6b 65 79 6e 75 6d 20 6c 61 62 6c 29 0a 09 20 20  keynum labl)..  
3ef0: 28 6c 6f 6f 70 20 72 75 6e 6e 75 6d 20 28 2b 20  (loop runnum (+ 
3f00: 6b 65 79 6e 75 6d 20 31 29 20 6b 65 79 76 65 63  keynum 1) keyvec
3f10: 20 28 63 6f 6e 73 20 6c 61 62 6c 20 72 65 73 29   (cons labl res)
3f20: 29 29 29 29 29 0a 20 20 20 20 3b 3b 20 42 79 20  ))))).    ;; By 
3f30: 68 65 72 65 20 74 68 65 20 68 64 72 6c 73 74 20  here the hdrlst 
3f40: 63 6f 6e 74 61 69 6e 73 20 61 20 6c 69 73 74 20  contains a list 
3f50: 6f 66 20 76 62 6f 78 65 73 20 63 6f 6e 74 61 69  of vboxes contai
3f60: 6e 69 6e 67 20 6e 6b 65 79 73 20 6c 61 62 65 6c  ning nkeys label
3f70: 73 0a 20 20 20 20 28 6c 65 74 20 6c 6f 6f 70 20  s.    (let loop 
3f80: 28 28 72 75 6e 6e 75 6d 20 20 30 29 0a 09 20 20  ((runnum  0)..  
3f90: 20 20 20 20 20 28 74 65 73 74 6e 75 6d 20 30 29       (testnum 0)
3fa0: 0a 09 20 20 20 20 20 20 20 28 74 65 73 74 76 65  ..       (testve
3fb0: 63 20 20 28 6d 61 6b 65 2d 76 65 63 74 6f 72 20  c  (make-vector 
3fc0: 6e 74 65 73 74 73 29 29 0a 09 20 20 20 20 20 20  ntests))..      
3fd0: 20 28 72 65 73 20 20 20 20 27 28 29 29 29 0a 20   (res    '())). 
3fe0: 20 20 20 20 20 28 63 6f 6e 64 0a 20 20 20 20 20       (cond.     
3ff0: 20 20 28 28 3e 3d 20 72 75 6e 6e 75 6d 20 6e 72    ((>= runnum nr
4000: 75 6e 73 29 20 23 66 29 20 3b 3b 20 20 28 76 65  uns) #f) ;;  (ve
4010: 63 74 6f 72 20 74 61 62 6c 65 68 65 61 64 65 72  ctor tableheader
4020: 20 72 75 6e 73 76 65 63 29 29 0a 20 20 20 20 20   runsvec)).     
4030: 20 20 28 28 3e 3d 20 74 65 73 74 6e 75 6d 20 6e    ((>= testnum n
4040: 74 65 73 74 73 29 20 0a 09 28 76 65 63 74 6f 72  tests) ..(vector
4050: 2d 73 65 74 21 20 72 75 6e 73 76 65 63 20 72 75  -set! runsvec ru
4060: 6e 6e 75 6d 20 74 65 73 74 76 65 63 29 0a 09 28  nnum testvec)..(
4070: 73 65 74 21 20 62 64 79 6c 73 74 20 28 63 6f 6e  set! bdylst (con
4080: 73 20 28 61 70 70 6c 79 20 69 75 70 3a 76 62 6f  s (apply iup:vbo
4090: 78 20 28 72 65 76 65 72 73 65 20 72 65 73 29 29  x (reverse res))
40a0: 20 62 64 79 6c 73 74 29 29 0a 09 28 6c 6f 6f 70   bdylst))..(loop
40b0: 20 28 2b 20 72 75 6e 6e 75 6d 20 31 29 20 30 20   (+ runnum 1) 0 
40c0: 28 6d 61 6b 65 2d 76 65 63 74 6f 72 20 6e 74 65  (make-vector nte
40d0: 73 74 73 29 20 27 28 29 29 29 0a 20 20 20 20 20  sts) '())).     
40e0: 20 20 28 65 6c 73 65 0a 09 28 6c 65 74 2a 20 28    (else..(let* (
40f0: 28 62 75 74 74 6f 6e 2d 6b 65 79 20 28 6d 6b 73  (button-key (mks
4100: 74 72 20 72 75 6e 6e 75 6d 20 74 65 73 74 6e 75  tr runnum testnu
4110: 6d 29 29 0a 09 20 20 20 20 20 20 20 28 62 75 74  m))..       (but
4120: 6e 20 20 20 20 20 20 20 28 69 75 70 3a 62 75 74  n       (iup:but
4130: 74 6f 6e 20 22 22 20 3b 3b 20 62 75 74 74 6f 6e  ton "" ;; button
4140: 2d 6b 65 79 20 0a 09 09 09 09 20 20 20 20 20 20  -key .....      
4150: 20 23 3a 73 69 7a 65 20 22 36 30 78 31 35 22 20   #:size "60x15" 
4160: 0a 09 09 09 09 20 20 20 20 20 20 20 3b 3b 20 23  .....       ;; #
4170: 3a 65 78 70 61 6e 64 20 22 48 4f 52 49 5a 4f 4e  :expand "HORIZON
4180: 54 41 4c 22 0a 09 09 09 09 20 20 20 20 20 20 20  TAL".....       
4190: 23 3a 66 6f 6e 74 73 69 7a 65 20 22 31 30 22 20  #:fontsize "10" 
41a0: 0a 09 09 09 09 20 20 20 20 20 20 20 23 3a 61 63  .....       #:ac
41b0: 74 69 6f 6e 20 28 6c 61 6d 62 64 61 20 28 78 29  tion (lambda (x)
41c0: 0a 09 09 09 09 09 09 20 20 28 6c 65 74 2a 20 28  .......  (let* (
41d0: 28 74 6f 6f 6c 70 61 74 68 20 28 63 61 72 20 28  (toolpath (car (
41e0: 61 72 67 76 29 29 29 0a 09 09 09 09 09 09 09 20  argv)))........ 
41f0: 28 62 75 74 74 6e 64 61 74 20 28 68 61 73 68 2d  (buttndat (hash-
4200: 74 61 62 6c 65 2d 72 65 66 20 2a 62 75 74 74 6f  table-ref *butto
4210: 6e 64 61 74 2a 20 62 75 74 74 6f 6e 2d 6b 65 79  ndat* button-key
4220: 29 29 0a 09 09 09 09 09 09 09 20 28 74 65 73 74  ))........ (test
4230: 2d 69 64 20 20 28 64 62 3a 74 65 73 74 2d 67 65  -id  (db:test-ge
4240: 74 2d 69 64 20 28 76 65 63 74 6f 72 2d 72 65 66  t-id (vector-ref
4250: 20 62 75 74 74 6e 64 61 74 20 33 29 29 29 0a 09   buttndat 3)))..
4260: 09 09 09 09 09 09 20 28 63 6d 64 20 20 28 63 6f  ...... (cmd  (co
4270: 6e 63 20 74 6f 6f 6c 70 61 74 68 20 22 20 2d 74  nc toolpath " -t
4280: 65 73 74 20 22 20 74 65 73 74 2d 69 64 20 22 26  est " test-id "&
4290: 22 29 29 29 0a 09 09 09 09 09 09 20 20 20 20 3b  "))).......    ;
42a0: 28 70 72 69 6e 74 20 22 4c 61 75 6e 63 68 69 6e  (print "Launchin
42b0: 67 20 22 20 63 6d 64 29 0a 09 09 09 09 09 09 20  g " cmd)....... 
42c0: 20 20 20 28 73 79 73 74 65 6d 20 63 6d 64 29 29     (system cmd))
42d0: 29 29 29 29 0a 09 20 20 28 68 61 73 68 2d 74 61  ))))..  (hash-ta
42e0: 62 6c 65 2d 73 65 74 21 20 2a 62 75 74 74 6f 6e  ble-set! *button
42f0: 64 61 74 2a 20 62 75 74 74 6f 6e 2d 6b 65 79 20  dat* button-key 
4300: 28 76 65 63 74 6f 72 20 30 20 22 31 30 30 20 31  (vector 0 "100 1
4310: 30 30 20 31 30 30 22 20 62 75 74 74 6f 6e 2d 6b  00 100" button-k
4320: 65 79 20 23 66 20 23 66 29 29 20 0a 09 20 20 28  ey #f #f)) ..  (
4330: 76 65 63 74 6f 72 2d 73 65 74 21 20 74 65 73 74  vector-set! test
4340: 76 65 63 20 74 65 73 74 6e 75 6d 20 62 75 74 6e  vec testnum butn
4350: 29 0a 09 20 20 28 6c 6f 6f 70 20 72 75 6e 6e 75  )..  (loop runnu
4360: 6d 20 28 2b 20 74 65 73 74 6e 75 6d 20 31 29 20  m (+ testnum 1) 
4370: 74 65 73 74 76 65 63 20 28 63 6f 6e 73 20 62 75  testvec (cons bu
4380: 74 6e 20 72 65 73 29 29 29 29 29 29 0a 20 20 20  tn res)))))).   
4390: 20 3b 3b 20 6e 6f 77 20 61 73 73 65 6d 62 6c 65   ;; now assemble
43a0: 20 74 68 65 20 68 64 72 6c 73 74 20 61 6e 64 20   the hdrlst and 
43b0: 62 64 79 6c 73 74 20 61 6e 64 20 6b 69 63 6b 20  bdylst and kick 
43c0: 6f 66 66 20 74 68 65 20 64 69 61 6c 6f 67 0a 20  off the dialog. 
43d0: 20 20 20 28 69 75 70 3a 73 68 6f 77 0a 20 20 20     (iup:show.   
43e0: 20 20 28 69 75 70 3a 64 69 61 6c 6f 67 20 0a 20    (iup:dialog . 
43f0: 20 20 20 20 20 23 3a 74 69 74 6c 65 20 22 4d 65       #:title "Me
4400: 67 61 74 65 73 74 20 64 61 73 68 62 6f 61 72 64  gatest dashboard
4410: 22 0a 20 20 20 20 20 20 28 69 75 70 3a 76 62 6f  ".      (iup:vbo
4420: 78 0a 09 28 61 70 70 6c 79 20 69 75 70 3a 68 62  x..(apply iup:hb
4430: 6f 78 20 0a 09 20 20 20 20 20 20 20 28 63 6f 6e  ox ..       (con
4440: 73 20 28 61 70 70 6c 79 20 69 75 70 3a 76 62 6f  s (apply iup:vbo
4450: 78 20 6c 66 74 6c 73 74 29 0a 09 09 20 20 20 20  x lftlst)...    
4460: 20 28 6c 69 73 74 20 0a 09 09 20 20 20 20 20 20   (list ...      
4470: 28 69 75 70 3a 76 62 6f 78 0a 09 09 20 20 20 20  (iup:vbox...    
4480: 20 20 20 3b 3b 20 74 68 65 20 68 65 61 64 65 72     ;; the header
4490: 0a 09 09 20 20 20 20 20 20 20 28 61 70 70 6c 79  ...       (apply
44a0: 20 69 75 70 3a 68 62 6f 78 20 28 72 65 76 65 72   iup:hbox (rever
44b0: 73 65 20 68 64 72 6c 73 74 29 29 0a 09 09 20 20  se hdrlst))...  
44c0: 20 20 20 20 20 28 61 70 70 6c 79 20 69 75 70 3a       (apply iup:
44d0: 68 62 6f 78 20 28 72 65 76 65 72 73 65 20 62 64  hbox (reverse bd
44e0: 79 6c 73 74 29 29 29 29 29 29 0a 20 20 20 20 20  ylst)))))).     
44f0: 20 20 63 6f 6e 74 72 6f 6c 73 29 29 29 0a 20 20    controls))).  
4500: 20 20 28 76 65 63 74 6f 72 20 6c 66 74 63 6f 6c    (vector lftcol
4510: 20 68 65 61 64 65 72 20 72 75 6e 73 76 65 63 29   header runsvec)
4520: 29 29 0a 0a 28 69 66 20 28 6f 72 20 28 61 72 67  ))..(if (or (arg
4530: 73 3a 67 65 74 2d 61 72 67 20 22 2d 72 6f 77 73  s:get-arg "-rows
4540: 22 29 0a 09 28 67 65 74 2d 65 6e 76 69 72 6f 6e  ")..(get-environ
4550: 6d 65 6e 74 2d 76 61 72 69 61 62 6c 65 20 22 44  ment-variable "D
4560: 41 53 48 42 4f 41 52 44 52 4f 57 53 22 20 29 29  ASHBOARDROWS" ))
4570: 0a 20 20 20 20 28 62 65 67 69 6e 0a 20 20 20 20  .    (begin.    
4580: 20 20 20 20 28 73 65 74 21 20 2a 6e 75 6d 2d 74      (set! *num-t
4590: 65 73 74 73 2a 20 28 73 74 72 69 6e 67 2d 3e 6e  ests* (string->n
45a0: 75 6d 62 65 72 20 28 6f 72 20 28 61 72 67 73 3a  umber (or (args:
45b0: 67 65 74 2d 61 72 67 20 22 2d 72 6f 77 73 22 29  get-arg "-rows")
45c0: 0a 09 09 09 09 09 20 20 20 20 20 20 28 67 65 74  ......      (get
45d0: 2d 65 6e 76 69 72 6f 6e 6d 65 6e 74 2d 76 61 72  -environment-var
45e0: 69 61 62 6c 65 20 22 44 41 53 48 42 4f 41 52 44  iable "DASHBOARD
45f0: 52 4f 57 53 22 29 29 29 29 0a 09 28 75 70 64 61  ROWS"))))..(upda
4600: 74 65 2d 72 75 6e 64 61 74 20 22 25 22 20 2a 6e  te-rundat "%" *n
4610: 75 6d 2d 72 75 6e 73 2a 20 22 25 22 20 22 25 22  um-runs* "%" "%"
4620: 29 29 0a 20 20 20 20 28 73 65 74 21 20 2a 6e 75  )).    (set! *nu
4630: 6d 2d 74 65 73 74 73 2a 20 28 6d 69 6e 20 28 6d  m-tests* (min (m
4640: 61 78 20 28 75 70 64 61 74 65 2d 72 75 6e 64 61  ax (update-runda
4650: 74 20 22 25 22 20 2a 6e 75 6d 2d 72 75 6e 73 2a  t "%" *num-runs*
4660: 20 22 25 22 20 22 25 22 29 20 38 29 20 32 30 29   "%" "%") 8) 20)
4670: 29 29 0a 0a 28 64 65 66 69 6e 65 20 2a 74 69 6d  ))..(define *tim
4680: 2a 20 28 69 75 70 3a 74 69 6d 65 72 29 29 0a 28  * (iup:timer)).(
4690: 64 65 66 69 6e 65 20 2a 6f 72 64 2a 20 23 66 29  define *ord* #f)
46a0: 0a 28 69 75 70 3a 61 74 74 72 69 62 75 74 65 2d  .(iup:attribute-
46b0: 73 65 74 21 20 2a 74 69 6d 2a 20 22 54 49 4d 45  set! *tim* "TIME
46c0: 22 20 33 30 30 29 0a 28 69 75 70 3a 61 74 74 72  " 300).(iup:attr
46d0: 69 62 75 74 65 2d 73 65 74 21 20 2a 74 69 6d 2a  ibute-set! *tim*
46e0: 20 22 52 55 4e 22 20 22 59 45 53 22 29 0a 0a 28   "RUN" "YES")..(
46f0: 64 65 66 69 6e 65 20 28 72 75 6e 2d 75 70 64 61  define (run-upda
4700: 74 65 20 78 29 0a 20 20 28 75 70 64 61 74 65 2d  te x).  (update-
4710: 62 75 74 74 6f 6e 73 20 75 69 64 61 74 20 2a 6e  buttons uidat *n
4720: 75 6d 2d 72 75 6e 73 2a 20 2a 6e 75 6d 2d 74 65  um-runs* *num-te
4730: 73 74 73 2a 29 0a 20 20 28 75 70 64 61 74 65 2d  sts*).  (update-
4740: 72 75 6e 64 61 74 20 28 68 61 73 68 2d 74 61 62  rundat (hash-tab
4750: 6c 65 2d 72 65 66 2f 64 65 66 61 75 6c 74 20 2a  le-ref/default *
4760: 73 65 61 72 63 68 70 61 74 74 73 2a 20 22 72 75  searchpatts* "ru
4770: 6e 6e 61 6d 65 22 20 22 25 22 29 20 2a 6e 75 6d  nname" "%") *num
4780: 2d 72 75 6e 73 2a 0a 09 09 20 28 68 61 73 68 2d  -runs*... (hash-
4790: 74 61 62 6c 65 2d 72 65 66 2f 64 65 66 61 75 6c  table-ref/defaul
47a0: 74 20 2a 73 65 61 72 63 68 70 61 74 74 73 2a 20  t *searchpatts* 
47b0: 22 74 65 73 74 2d 6e 61 6d 65 22 20 22 25 22 29  "test-name" "%")
47c0: 0a 09 09 20 28 68 61 73 68 2d 74 61 62 6c 65 2d  ... (hash-table-
47d0: 72 65 66 2f 64 65 66 61 75 6c 74 20 2a 73 65 61  ref/default *sea
47e0: 72 63 68 70 61 74 74 73 2a 20 22 69 74 65 6d 2d  rchpatts* "item-
47f0: 6e 61 6d 65 22 20 22 25 22 29 29 29 0a 0a 28 63  name" "%")))..(c
4800: 6f 6e 64 20 0a 20 28 28 61 72 67 73 3a 67 65 74  ond . ((args:get
4810: 2d 61 72 67 20 22 2d 72 75 6e 22 29 0a 20 20 28  -arg "-run").  (
4820: 6c 65 74 20 28 28 72 75 6e 69 64 20 28 73 74 72  let ((runid (str
4830: 69 6e 67 2d 3e 6e 75 6d 62 65 72 20 28 61 72 67  ing->number (arg
4840: 73 3a 67 65 74 2d 61 72 67 20 22 2d 72 75 6e 22  s:get-arg "-run"
4850: 29 29 29 29 0a 20 20 20 20 28 69 66 20 72 75 6e  )))).    (if run
4860: 69 64 0a 09 28 62 65 67 69 6e 0a 09 20 20 28 6c  id..(begin..  (l
4870: 61 6d 62 64 61 20 28 78 29 0a 09 20 20 20 20 28  ambda (x)..    (
4880: 6f 6e 2d 65 78 69 74 20 28 6c 61 6d 62 64 61 20  on-exit (lambda 
4890: 28 29 0a 09 09 20 20 20 20 20 20 20 28 73 71 6c  ()...       (sql
48a0: 69 74 65 33 3a 66 69 6e 61 6c 69 7a 65 21 20 2a  ite3:finalize! *
48b0: 64 62 2a 29 29 29 0a 09 20 20 20 20 28 65 78 61  db*)))..    (exa
48c0: 6d 69 6e 65 2d 72 75 6e 20 2a 64 62 2a 20 72 75  mine-run *db* ru
48d0: 6e 69 64 29 29 29 0a 09 28 62 65 67 69 6e 0a 09  nid)))..(begin..
48e0: 20 20 28 70 72 69 6e 74 20 22 45 52 52 4f 52 3a    (print "ERROR:
48f0: 20 72 75 6e 69 64 20 69 73 20 6e 6f 74 20 61 20   runid is not a 
4900: 6e 75 6d 62 65 72 20 22 20 28 61 72 67 73 3a 67  number " (args:g
4910: 65 74 2d 61 72 67 20 22 2d 72 75 6e 22 29 29 0a  et-arg "-run")).
4920: 09 20 20 28 65 78 69 74 20 31 29 29 29 29 29 0a  .  (exit 1))))).
4930: 20 28 28 61 72 67 73 3a 67 65 74 2d 61 72 67 20   ((args:get-arg 
4940: 22 2d 74 65 73 74 22 29 0a 20 20 20 20 28 6c 65  "-test").    (le
4950: 74 20 28 28 74 65 73 74 69 64 20 28 73 74 72 69  t ((testid (stri
4960: 6e 67 2d 3e 6e 75 6d 62 65 72 20 28 61 72 67 73  ng->number (args
4970: 3a 67 65 74 2d 61 72 67 20 22 2d 74 65 73 74 22  :get-arg "-test"
4980: 29 29 29 29 0a 20 20 20 20 28 69 66 20 74 65 73  )))).    (if tes
4990: 74 69 64 0a 09 28 65 78 61 6d 69 6e 65 2d 74 65  tid..(examine-te
49a0: 73 74 20 2a 64 62 2a 20 74 65 73 74 69 64 29 0a  st *db* testid).
49b0: 09 28 62 65 67 69 6e 0a 09 20 20 28 70 72 69 6e  .(begin..  (prin
49c0: 74 20 22 45 52 52 4f 52 3a 20 74 65 73 74 69 64  t "ERROR: testid
49d0: 20 69 73 20 6e 6f 74 20 61 20 6e 75 6d 62 65 72   is not a number
49e0: 20 22 20 28 61 72 67 73 3a 67 65 74 2d 61 72 67   " (args:get-arg
49f0: 20 22 2d 74 65 73 74 22 29 29 0a 09 20 20 28 65   "-test"))..  (e
4a00: 78 69 74 20 31 29 29 29 29 29 0a 20 28 65 6c 73  xit 1))))). (els
4a10: 65 0a 20 20 28 73 65 74 21 20 75 69 64 61 74 20  e.  (set! uidat 
4a20: 28 6d 61 6b 65 2d 64 61 73 68 62 6f 61 72 64 2d  (make-dashboard-
4a30: 62 75 74 74 6f 6e 73 20 2a 6e 75 6d 2d 72 75 6e  buttons *num-run
4a40: 73 2a 20 2a 6e 75 6d 2d 74 65 73 74 73 2a 20 64  s* *num-tests* d
4a50: 62 6b 65 79 73 29 29 0a 20 20 28 69 75 70 3a 63  bkeys)).  (iup:c
4a60: 61 6c 6c 62 61 63 6b 2d 73 65 74 21 20 2a 74 69  allback-set! *ti
4a70: 6d 2a 0a 09 09 20 20 20 20 20 22 41 43 54 49 4f  m*...     "ACTIO
4a80: 4e 5f 43 42 22 0a 09 09 20 20 20 20 20 28 6c 61  N_CB"...     (la
4a90: 6d 62 64 61 20 28 78 29 0a 09 09 20 20 20 20 20  mbda (x)...     
4aa0: 20 20 28 72 75 6e 2d 75 70 64 61 74 65 20 78 29    (run-update x)
4ab0: 29 29 29 29 0a 09 09 20 20 20 20 20 20 20 3b 28  ))))...       ;(
4ac0: 70 72 69 6e 74 20 78 29 29 29 29 29 0a 0a 28 69  print x)))))..(i
4ad0: 75 70 3a 6d 61 69 6e 2d 6c 6f 6f 70 29 0a        up:main-loop).