Artifact
e9212eda7d2fcf5ab8e3125e839561b8b28b7187 :
File
dashboard.scm
— part of check-in
[112fdec9c0]
at
2011-07-13 23:15:30
on branch trunk
— Re-factored dashboard to elimnate using threads and to use the iup:timer instead
(user:
mrwellan
size: 19166)
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).