Megatest

Hex Artifact Content
Login

Artifact 9964e638671fdcc50ea032f0fe2cf0cdbf4e7c74:


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 31 39 2c 20 4d 61 74 74  right 2019, Matt
0060: 68 65 77 20 57 65 6c 6c 61 6e 64 2e 0a 3b 3b 20  hew Welland..;; 
0070: 0a 3b 3b 20 54 68 69 73 20 66 69 6c 65 20 69 73  .;; This file is
0080: 20 70 61 72 74 20 6f 66 20 4d 65 67 61 74 65 73   part of Megates
0090: 74 2e 0a 3b 3b 20 0a 3b 3b 20 20 20 20 20 4d 65  t..;; .;;     Me
00a0: 67 61 74 65 73 74 20 69 73 20 66 72 65 65 20 73  gatest is free s
00b0: 6f 66 74 77 61 72 65 3a 20 79 6f 75 20 63 61 6e  oftware: you can
00c0: 20 72 65 64 69 73 74 72 69 62 75 74 65 20 69 74   redistribute it
00d0: 20 61 6e 64 2f 6f 72 20 6d 6f 64 69 66 79 0a 3b   and/or modify.;
00e0: 3b 20 20 20 20 20 69 74 20 75 6e 64 65 72 20 74  ;     it under t
00f0: 68 65 20 74 65 72 6d 73 20 6f 66 20 74 68 65 20  he terms of the 
0100: 47 4e 55 20 47 65 6e 65 72 61 6c 20 50 75 62 6c  GNU General Publ
0110: 69 63 20 4c 69 63 65 6e 73 65 20 61 73 20 70 75  ic License as pu
0120: 62 6c 69 73 68 65 64 20 62 79 0a 3b 3b 20 20 20  blished by.;;   
0130: 20 20 74 68 65 20 46 72 65 65 20 53 6f 66 74 77    the Free Softw
0140: 61 72 65 20 46 6f 75 6e 64 61 74 69 6f 6e 2c 20  are Foundation, 
0150: 65 69 74 68 65 72 20 76 65 72 73 69 6f 6e 20 33  either version 3
0160: 20 6f 66 20 74 68 65 20 4c 69 63 65 6e 73 65 2c   of the License,
0170: 20 6f 72 0a 3b 3b 20 20 20 20 20 28 61 74 20 79   or.;;     (at y
0180: 6f 75 72 20 6f 70 74 69 6f 6e 29 20 61 6e 79 20  our option) any 
0190: 6c 61 74 65 72 20 76 65 72 73 69 6f 6e 2e 0a 3b  later version..;
01a0: 3b 20 0a 3b 3b 20 20 20 20 20 4d 65 67 61 74 65  ; .;;     Megate
01b0: 73 74 20 69 73 20 64 69 73 74 72 69 62 75 74 65  st is distribute
01c0: 64 20 69 6e 20 74 68 65 20 68 6f 70 65 20 74 68  d in the hope th
01d0: 61 74 20 69 74 20 77 69 6c 6c 20 62 65 20 75 73  at it will be us
01e0: 65 66 75 6c 2c 0a 3b 3b 20 20 20 20 20 62 75 74  eful,.;;     but
01f0: 20 57 49 54 48 4f 55 54 20 41 4e 59 20 57 41 52   WITHOUT ANY WAR
0200: 52 41 4e 54 59 3b 20 77 69 74 68 6f 75 74 20 65  RANTY; without e
0210: 76 65 6e 20 74 68 65 20 69 6d 70 6c 69 65 64 20  ven the implied 
0220: 77 61 72 72 61 6e 74 79 20 6f 66 0a 3b 3b 20 20  warranty of.;;  
0230: 20 20 20 4d 45 52 43 48 41 4e 54 41 42 49 4c 49     MERCHANTABILI
0240: 54 59 20 6f 72 20 46 49 54 4e 45 53 53 20 46 4f  TY or FITNESS FO
0250: 52 20 41 20 50 41 52 54 49 43 55 4c 41 52 20 50  R A PARTICULAR P
0260: 55 52 50 4f 53 45 2e 20 20 53 65 65 20 74 68 65  URPOSE.  See the
0270: 0a 3b 3b 20 20 20 20 20 47 4e 55 20 47 65 6e 65  .;;     GNU Gene
0280: 72 61 6c 20 50 75 62 6c 69 63 20 4c 69 63 65 6e  ral Public Licen
0290: 73 65 20 66 6f 72 20 6d 6f 72 65 20 64 65 74 61  se for more deta
02a0: 69 6c 73 2e 0a 3b 3b 20 0a 3b 3b 20 20 20 20 20  ils..;; .;;     
02b0: 59 6f 75 20 73 68 6f 75 6c 64 20 68 61 76 65 20  You should have 
02c0: 72 65 63 65 69 76 65 64 20 61 20 63 6f 70 79 20  received a copy 
02d0: 6f 66 20 74 68 65 20 47 4e 55 20 47 65 6e 65 72  of the GNU Gener
02e0: 61 6c 20 50 75 62 6c 69 63 20 4c 69 63 65 6e 73  al Public Licens
02f0: 65 0a 3b 3b 20 20 20 20 20 61 6c 6f 6e 67 20 77  e.;;     along w
0300: 69 74 68 20 4d 65 67 61 74 65 73 74 2e 20 20 49  ith Megatest.  I
0310: 66 20 6e 6f 74 2c 20 73 65 65 20 3c 68 74 74 70  f not, see <http
0320: 3a 2f 2f 77 77 77 2e 67 6e 75 2e 6f 72 67 2f 6c  ://www.gnu.org/l
0330: 69 63 65 6e 73 65 73 2f 3e 2e 0a 0a 3b 3b 3d 3d  icenses/>...;;==
0340: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0350: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0360: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0370: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0380: 3d 3d 3d 3d 0a 0a 28 64 65 63 6c 61 72 65 20 28  ====..(declare (
0390: 75 6e 69 74 20 6d 65 67 61 6d 6f 64 29 29 0a 3b  unit megamod)).;
03a0: 3b 20 28 64 65 63 6c 61 72 65 20 28 75 73 65 73  ; (declare (uses
03b0: 20 63 6f 6d 6d 6f 6e 6d 6f 64 29 29 0a 3b 3b 20   commonmod)).;; 
03c0: 28 64 65 63 6c 61 72 65 20 28 75 73 65 73 20 64  (declare (uses d
03d0: 62 6d 6f 64 29 29 0a 3b 3b 20 3b 3b 28 64 65 63  bmod)).;; ;;(dec
03e0: 6c 61 72 65 20 28 75 73 65 73 20 61 70 69 6d 6f  lare (uses apimo
03f0: 64 29 29 0a 3b 3b 20 28 64 65 63 6c 61 72 65 20  d)).;; (declare 
0400: 28 75 73 65 73 20 66 74 61 69 6c 29 29 0a 3b 3b  (uses ftail)).;;
0410: 20 3b 3b 20 28 64 65 63 6c 61 72 65 20 28 75 73   ;; (declare (us
0420: 65 73 20 72 6d 74 6d 6f 64 29 29 0a 3b 3b 20 28  es rmtmod)).;; (
0430: 64 65 63 6c 61 72 65 20 28 75 73 65 73 20 63 6f  declare (uses co
0440: 6d 6d 6f 6e 6d 6f 64 29 29 0a 3b 3b 20 28 64 65  mmonmod)).;; (de
0450: 63 6c 61 72 65 20 28 75 73 65 73 20 61 70 69 6d  clare (uses apim
0460: 6f 64 29 29 0a 3b 3b 20 28 64 65 63 6c 61 72 65  od)).;; (declare
0470: 20 28 75 73 65 73 20 61 72 63 68 69 76 65 6d 6f   (uses archivemo
0480: 64 29 29 0a 3b 3b 20 28 64 65 63 6c 61 72 65 20  d)).;; (declare 
0490: 28 75 73 65 73 20 63 6c 69 65 6e 74 6d 6f 64 29  (uses clientmod)
04a0: 29 0a 3b 3b 20 28 64 65 63 6c 61 72 65 20 28 75  ).;; (declare (u
04b0: 73 65 73 20 64 62 6d 6f 64 29 29 0a 3b 3b 20 28  ses dbmod)).;; (
04c0: 64 65 63 6c 61 72 65 20 28 75 73 65 73 20 64 63  declare (uses dc
04d0: 6f 6d 6d 6f 6e 6d 6f 64 29 29 0a 3b 3b 20 28 64  ommonmod)).;; (d
04e0: 65 63 6c 61 72 65 20 28 75 73 65 73 20 65 6e 76  eclare (uses env
04f0: 6d 6f 64 29 29 0a 3b 3b 20 28 64 65 63 6c 61 72  mod)).;; (declar
0500: 65 20 28 75 73 65 73 20 65 7a 73 74 65 70 73 6d  e (uses ezstepsm
0510: 6f 64 29 29 0a 3b 3b 20 28 64 65 63 6c 61 72 65  od)).;; (declare
0520: 20 28 75 73 65 73 20 69 74 65 6d 73 6d 6f 64 29   (uses itemsmod)
0530: 29 0a 3b 3b 20 28 64 65 63 6c 61 72 65 20 28 75  ).;; (declare (u
0540: 73 65 73 20 6b 65 79 73 6d 6f 64 29 29 0a 3b 3b  ses keysmod)).;;
0550: 20 28 64 65 63 6c 61 72 65 20 28 75 73 65 73 20   (declare (uses 
0560: 6c 61 75 6e 63 68 6d 6f 64 29 29 0a 3b 3b 20 28  launchmod)).;; (
0570: 64 65 63 6c 61 72 65 20 28 75 73 65 73 20 6f 64  declare (uses od
0580: 73 6d 6f 64 29 29 0a 3b 3b 20 28 64 65 63 6c 61  smod)).;; (decla
0590: 72 65 20 28 75 73 65 73 20 70 72 6f 63 65 73 73  re (uses process
05a0: 6d 6f 64 29 29 0a 3b 3b 20 28 64 65 63 6c 61 72  mod)).;; (declar
05b0: 65 20 28 75 73 65 73 20 72 75 6e 63 6f 6e 66 69  e (uses runconfi
05c0: 67 6d 6f 64 29 29 0a 3b 3b 20 28 64 65 63 6c 61  gmod)).;; (decla
05d0: 72 65 20 28 75 73 65 73 20 72 75 6e 73 6d 6f 64  re (uses runsmod
05e0: 29 29 0a 3b 3b 20 28 64 65 63 6c 61 72 65 20 28  )).;; (declare (
05f0: 75 73 65 73 20 73 65 72 76 65 72 6d 6f 64 29 29  uses servermod))
0600: 0a 3b 3b 20 28 64 65 63 6c 61 72 65 20 28 75 73  .;; (declare (us
0610: 65 73 20 73 75 62 72 75 6e 6d 6f 64 29 29 0a 3b  es subrunmod)).;
0620: 3b 20 28 64 65 63 6c 61 72 65 20 28 75 73 65 73  ; (declare (uses
0630: 20 74 61 73 6b 73 6d 6f 64 29 29 0a 3b 3b 20 28   tasksmod)).;; (
0640: 64 65 63 6c 61 72 65 20 28 75 73 65 73 20 74 65  declare (uses te
0650: 73 74 73 6d 6f 64 29 29 0a 3b 3b 20 28 64 65 63  stsmod)).;; (dec
0660: 6c 61 72 65 20 28 75 73 65 73 20 76 67 6d 6f 64  lare (uses vgmod
0670: 29 29 0a 0a 28 6d 6f 64 75 6c 65 20 6d 65 67 61  ))..(module mega
0680: 6d 6f 64 0a 09 2a 0a 09 0a 28 69 6d 70 6f 72 74  mod..*...(import
0690: 20 73 63 68 65 6d 65 20 63 68 69 63 6b 65 6e 20   scheme chicken 
06a0: 64 61 74 61 2d 73 74 72 75 63 74 75 72 65 73 20  data-structures 
06b0: 65 78 74 72 61 73 29 0a 28 75 73 65 20 0a 20 28  extras).(use . (
06c0: 70 72 65 66 69 78 20 62 61 73 65 36 34 20 62 61  prefix base64 ba
06d0: 73 65 36 34 3a 29 0a 20 28 70 72 65 66 69 78 20  se64:). (prefix 
06e0: 64 62 69 20 64 62 69 3a 29 0a 20 28 70 72 65 66  dbi dbi:). (pref
06f0: 69 78 20 6e 61 6e 6f 6d 73 67 20 6e 6d 73 67 3a  ix nanomsg nmsg:
0700: 29 0a 20 28 70 72 65 66 69 78 20 73 71 6c 69 74  ). (prefix sqlit
0710: 65 33 20 73 71 6c 69 74 65 33 3a 29 0a 20 63 61  e3 sqlite3:). ca
0720: 6c 6c 2d 77 69 74 68 2d 65 6e 76 69 72 6f 6e 6d  ll-with-environm
0730: 65 6e 74 2d 76 61 72 69 61 62 6c 65 73 0a 20 63  ent-variables. c
0740: 61 6e 76 61 73 2d 64 72 61 77 0a 20 63 73 76 0a  anvas-draw. csv.
0750: 20 63 73 76 2d 78 6d 6c 0a 20 64 61 74 61 2d 73   csv-xml. data-s
0760: 74 72 75 63 74 75 72 65 73 0a 20 64 69 72 65 63  tructures. direc
0770: 74 6f 72 79 2d 75 74 69 6c 73 0a 20 64 6f 74 2d  tory-utils. dot-
0780: 6c 6f 63 6b 69 6e 67 0a 20 65 78 74 72 61 73 0a  locking. extras.
0790: 20 66 69 6c 65 73 0a 20 66 6d 74 0a 20 66 6f 72   files. fmt. for
07a0: 6d 61 74 0a 20 68 6f 73 74 69 6e 66 6f 0a 20 68  mat. hostinfo. h
07b0: 74 74 70 2d 63 6c 69 65 6e 74 0a 20 69 6e 74 61  ttp-client. inta
07c0: 72 77 65 62 0a 20 69 72 72 65 67 65 78 0a 20 28  rweb. irregex. (
07d0: 70 72 65 66 69 78 20 69 75 70 20 69 75 70 3a 29  prefix iup iup:)
07e0: 0a 20 6d 61 74 63 68 61 62 6c 65 0a 20 6d 64 35  . matchable. md5
07f0: 0a 20 6d 65 73 73 61 67 65 2d 64 69 67 65 73 74  . message-digest
0800: 0a 20 70 61 74 68 6e 61 6d 65 2d 65 78 70 61 6e  . pathname-expan
0810: 64 0a 20 70 6b 74 73 0a 20 70 6f 72 74 73 0a 20  d. pkts. ports. 
0820: 70 6f 73 69 78 0a 20 3b 3b 20 71 75 65 75 65 0a  posix. ;; queue.
0830: 20 72 65 67 65 78 0a 20 72 65 67 65 78 2d 63 61   regex. regex-ca
0840: 73 65 0a 20 73 31 31 6e 0a 20 73 70 61 72 73 65  se. s11n. sparse
0850: 2d 76 65 63 74 6f 72 73 0a 20 73 70 69 66 66 79  -vectors. spiffy
0860: 0a 20 73 70 69 66 66 79 2d 64 69 72 65 63 74 6f  . spiffy-directo
0870: 72 79 2d 6c 69 73 74 69 6e 67 0a 20 73 70 69 66  ry-listing. spif
0880: 66 79 2d 72 65 71 75 65 73 74 2d 76 61 72 73 0a  fy-request-vars.
0890: 20 73 71 6c 2d 64 65 2d 6c 69 74 65 0a 20 73 72   sql-de-lite. sr
08a0: 66 69 2d 31 0a 20 73 72 66 69 2d 34 0a 20 73 72  fi-1. srfi-4. sr
08b0: 66 69 2d 31 33 0a 20 73 72 66 69 2d 31 38 0a 20  fi-13. srfi-18. 
08c0: 73 72 66 69 2d 36 39 0a 20 73 74 61 63 6b 0a 20  srfi-69. stack. 
08d0: 73 74 6d 6c 32 0a 20 74 63 70 0a 20 74 79 70 65  stml2. tcp. type
08e0: 64 2d 72 65 63 6f 72 64 73 0a 20 75 64 70 0a 20  d-records. udp. 
08f0: 75 72 69 2d 63 6f 6d 6d 6f 6e 0a 20 7a 33 0a 20  uri-common. z3. 
0900: 29 0a 0a 28 75 73 65 20 28 70 72 65 66 69 78 20  )..(use (prefix 
0910: 6d 74 63 6f 6e 66 69 67 66 20 63 6f 6e 66 69 67  mtconfigf config
0920: 66 3a 29 29 0a 28 64 65 66 69 6e 65 20 72 65 61  f:)).(define rea
0930: 64 2d 63 6f 6e 66 69 67 20 63 6f 6e 66 69 67 66  d-config configf
0940: 3a 72 65 61 64 2d 63 6f 6e 66 69 67 29 0a 28 64  :read-config).(d
0950: 65 66 69 6e 65 20 66 69 6e 64 2d 61 6e 64 2d 72  efine find-and-r
0960: 65 61 64 2d 63 6f 6e 66 69 67 20 63 6f 6e 66 69  ead-config confi
0970: 67 66 3a 66 69 6e 64 2d 61 6e 64 2d 72 65 61 64  gf:find-and-read
0980: 2d 63 6f 6e 66 69 67 29 0a 28 64 65 66 69 6e 65  -config).(define
0990: 20 63 6f 6e 66 69 67 3a 65 76 61 6c 2d 73 74 72   config:eval-str
09a0: 69 6e 67 2d 69 6e 2d 65 6e 76 69 72 6f 6e 6d 65  ing-in-environme
09b0: 6e 74 20 63 6f 6e 66 69 67 66 3a 65 76 61 6c 2d  nt configf:eval-
09c0: 73 74 72 69 6e 67 2d 69 6e 2d 65 6e 76 69 72 6f  string-in-enviro
09d0: 6e 6d 65 6e 74 29 0a 0a 28 69 6d 70 6f 72 74 20  nment)..(import 
09e0: 63 61 6e 76 61 73 2d 64 72 61 77 2d 69 75 70 20  canvas-draw-iup 
09f0: 73 70 69 66 66 79 29 0a 0a 3b 3b 20 28 69 6d 70  spiffy)..;; (imp
0a00: 6f 72 74 20 61 70 69 6d 6f 64 29 0a 3b 3b 20 28  ort apimod).;; (
0a10: 69 6d 70 6f 72 74 20 61 72 63 68 69 76 65 6d 6f  import archivemo
0a20: 64 29 0a 3b 3b 20 28 69 6d 70 6f 72 74 20 63 6c  d).;; (import cl
0a30: 69 65 6e 74 6d 6f 64 29 0a 3b 3b 20 28 69 6d 70  ientmod).;; (imp
0a40: 6f 72 74 20 63 6f 6d 6d 6f 6e 6d 6f 64 29 0a 3b  ort commonmod).;
0a50: 3b 20 28 69 6d 70 6f 72 74 20 64 62 6d 6f 64 29  ; (import dbmod)
0a60: 0a 3b 3b 20 28 69 6d 70 6f 72 74 20 64 63 6f 6d  .;; (import dcom
0a70: 6d 6f 6e 6d 6f 64 29 0a 3b 3b 20 28 69 6d 70 6f  monmod).;; (impo
0a80: 72 74 20 65 6e 76 6d 6f 64 29 0a 3b 3b 20 28 69  rt envmod).;; (i
0a90: 6d 70 6f 72 74 20 65 7a 73 74 65 70 73 6d 6f 64  mport ezstepsmod
0aa0: 29 0a 3b 3b 20 28 69 6d 70 6f 72 74 20 66 74 61  ).;; (import fta
0ab0: 69 6c 29 0a 3b 3b 20 28 69 6d 70 6f 72 74 20 69  il).;; (import i
0ac0: 74 65 6d 73 6d 6f 64 29 0a 3b 3b 20 28 69 6d 70  temsmod).;; (imp
0ad0: 6f 72 74 20 6b 65 79 73 6d 6f 64 29 0a 3b 3b 20  ort keysmod).;; 
0ae0: 28 69 6d 70 6f 72 74 20 6c 61 75 6e 63 68 6d 6f  (import launchmo
0af0: 64 29 0a 3b 3b 20 28 69 6d 70 6f 72 74 20 6f 64  d).;; (import od
0b00: 73 6d 6f 64 29 0a 3b 3b 20 28 69 6d 70 6f 72 74  smod).;; (import
0b10: 20 70 72 6f 63 65 73 73 6d 6f 64 29 0a 3b 3b 20   processmod).;; 
0b20: 3b 3b 20 28 69 6d 70 6f 72 74 20 72 6d 74 6d 6f  ;; (import rmtmo
0b30: 64 29 0a 3b 3b 20 28 69 6d 70 6f 72 74 20 72 75  d).;; (import ru
0b40: 6e 63 6f 6e 66 69 67 6d 6f 64 29 0a 3b 3b 20 28  nconfigmod).;; (
0b50: 69 6d 70 6f 72 74 20 72 75 6e 73 6d 6f 64 29 0a  import runsmod).
0b60: 3b 3b 20 28 69 6d 70 6f 72 74 20 73 65 72 76 65  ;; (import serve
0b70: 72 6d 6f 64 29 0a 3b 3b 20 28 69 6d 70 6f 72 74  rmod).;; (import
0b80: 20 73 75 62 72 75 6e 6d 6f 64 29 0a 3b 3b 20 28   subrunmod).;; (
0b90: 69 6d 70 6f 72 74 20 74 61 73 6b 73 6d 6f 64 29  import tasksmod)
0ba0: 0a 3b 3b 20 28 69 6d 70 6f 72 74 20 74 65 73 74  .;; (import test
0bb0: 73 6d 6f 64 29 0a 3b 3b 20 28 69 6d 70 6f 72 74  smod).;; (import
0bc0: 20 76 67 6d 6f 64 29 0a 0a 28 75 73 65 20 28 70   vgmod)..(use (p
0bd0: 72 65 66 69 78 20 75 6c 65 78 20 75 6c 65 78 3a  refix ulex ulex:
0be0: 29 29 0a 0a 28 69 6e 63 6c 75 64 65 20 22 63 6f  ))..(include "co
0bf0: 6d 6d 6f 6e 5f 72 65 63 6f 72 64 73 2e 73 63 6d  mmon_records.scm
0c00: 22 29 0a 28 69 6e 63 6c 75 64 65 20 22 64 62 5f  ").(include "db_
0c10: 72 65 63 6f 72 64 73 2e 73 63 6d 22 29 0a 28 69  records.scm").(i
0c20: 6e 63 6c 75 64 65 20 22 6b 65 79 5f 72 65 63 6f  nclude "key_reco
0c30: 72 64 73 2e 73 63 6d 22 29 0a 28 69 6e 63 6c 75  rds.scm").(inclu
0c40: 64 65 20 22 72 75 6e 5f 72 65 63 6f 72 64 73 2e  de "run_records.
0c50: 73 63 6d 22 29 0a 28 69 6e 63 6c 75 64 65 20 22  scm").(include "
0c60: 74 61 73 6b 5f 72 65 63 6f 72 64 73 2e 73 63 6d  task_records.scm
0c70: 22 29 0a 28 69 6e 63 6c 75 64 65 20 22 74 65 73  ").(include "tes
0c80: 74 5f 72 65 63 6f 72 64 73 2e 73 63 6d 22 29 0a  t_records.scm").
0c90: 28 69 6e 63 6c 75 64 65 20 22 76 67 5f 72 65 63  (include "vg_rec
0ca0: 6f 72 64 73 2e 73 63 6d 22 29 0a 0a 3b 3b 3d 3d  ords.scm")..;;==
0cb0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0cc0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0cd0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0ce0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0cf0: 3d 3d 3d 3d 0a 3b 3b 20 4c 20 4f 20 43 20 4b 20  ====.;; L O C K 
0d00: 49 20 4e 20 47 20 20 20 4d 20 45 20 43 20 48 20  I N G   M E C H 
0d10: 41 20 4e 20 49 20 53 20 4d 20 53 20 0a 3b 3b 3d  A N I S M S .;;=
0d20: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0d30: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0d40: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0d50: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
0d60: 3d 3d 3d 3d 3d 0a 0a 28 69 6e 63 6c 75 64 65 20  =====..(include 
0d70: 22 6d 65 67 61 74 65 73 74 2d 66 6f 73 73 69 6c  "megatest-fossil
0d80: 2d 68 61 73 68 2e 73 63 6d 22 29 0a 28 69 6e 63  -hash.scm").(inc
0d90: 6c 75 64 65 20 22 6d 65 67 61 74 65 73 74 2d 76  lude "megatest-v
0da0: 65 72 73 69 6f 6e 2e 73 63 6d 22 29 0a 0a 3b 3b  ersion.scm")..;;
0db0: 20 67 6c 6f 62 61 6c 73 0a 28 64 65 66 69 6e 65   globals.(define
0dc0: 20 2a 77 72 69 74 65 73 2d 74 6f 74 61 6c 2d 64   *writes-total-d
0dd0: 65 6c 61 79 2a 20 30 29 0a 28 64 65 66 69 6e 65  elay* 0).(define
0de0: 20 2a 65 78 69 74 2d 73 74 61 72 74 65 64 2a 20   *exit-started* 
0df0: 23 66 29 0a 28 64 65 66 69 6e 65 20 2a 6c 61 73  #f).(define *las
0e00: 74 2d 6d 6f 6e 69 74 6f 72 2d 75 70 64 61 74 65  t-monitor-update
0e10: 2d 74 69 6d 65 2a 20 30 29 0a 0a 28 64 65 66 69  -time* 0)..(defi
0e20: 6e 65 20 2a 74 69 6d 2a 20 28 69 75 70 3a 74 69  ne *tim* (iup:ti
0e30: 6d 65 72 29 29 0a 0a 3b 3b 20 54 68 65 20 77 61  mer))..;; The wa
0e40: 74 63 68 64 6f 67 20 69 73 20 74 6f 20 6b 65 65  tchdog is to kee
0e50: 70 20 61 6e 20 65 79 65 20 6f 6e 20 74 68 69 6e  p an eye on thin
0e60: 67 73 20 6c 69 6b 65 20 64 62 20 73 79 6e 63 20  gs like db sync 
0e70: 65 74 63 2e 0a 3b 3b 0a 0a 3b 3b 20 54 4f 44 4f  etc..;;..;; TODO
0e80: 3a 20 66 6f 72 20 6d 75 6c 74 69 70 6c 65 20 61  : for multiple a
0e90: 72 65 61 73 2c 20 77 65 20 77 69 6c 6c 20 68 61  reas, we will ha
0ea0: 76 65 20 6d 75 6c 74 69 70 6c 65 20 77 61 74 63  ve multiple watc
0eb0: 68 64 6f 67 73 3b 20 61 6e 64 20 6d 75 6c 74 69  hdogs; and multi
0ec0: 70 6c 65 20 74 68 72 65 61 64 73 20 74 6f 20 6d  ple threads to m
0ed0: 61 6e 61 67 65 0a 28 64 65 66 69 6e 65 20 2a 77  anage.(define *w
0ee0: 61 74 63 68 64 6f 67 2a 20 28 6d 61 6b 65 2d 74  atchdog* (make-t
0ef0: 68 72 65 61 64 0a 09 09 20 20 20 20 28 6c 61 6d  hread...    (lam
0f00: 62 64 61 20 28 29 0a 09 09 20 20 20 20 20 20 28  bda ()...      (
0f10: 68 61 6e 64 6c 65 2d 65 78 63 65 70 74 69 6f 6e  handle-exception
0f20: 73 0a 09 09 09 20 20 65 78 6e 0a 09 09 09 20 20  s....  exn....  
0f30: 28 62 65 67 69 6e 0a 09 09 09 20 20 20 20 28 70  (begin....    (p
0f40: 72 69 6e 74 2d 63 61 6c 6c 2d 63 68 61 69 6e 29  rint-call-chain)
0f50: 0a 09 09 09 20 20 20 20 28 70 72 69 6e 74 20 22  ....    (print "
0f60: 20 6d 65 73 73 61 67 65 3a 20 22 20 28 28 63 6f   message: " ((co
0f70: 6e 64 69 74 69 6f 6e 2d 70 72 6f 70 65 72 74 79  ndition-property
0f80: 2d 61 63 63 65 73 73 6f 72 20 27 65 78 6e 20 27  -accessor 'exn '
0f90: 6d 65 73 73 61 67 65 29 20 65 78 6e 29 29 29 0a  message) exn))).
0fa0: 09 09 09 28 63 6f 6d 6d 6f 6e 3a 77 61 74 63 68  ...(common:watch
0fb0: 64 6f 67 29 29 29 0a 09 09 20 20 20 20 22 57 61  dog)))...    "Wa
0fc0: 74 63 68 64 6f 67 20 74 68 72 65 61 64 22 29 29  tchdog thread"))
0fd0: 0a 0a 28 69 6e 63 6c 75 64 65 20 22 61 70 69 2d  ..(include "api-
0fe0: 69 6e 63 2e 73 63 6d 22 29 0a 28 69 6e 63 6c 75  inc.scm").(inclu
0ff0: 64 65 20 22 61 72 63 68 69 76 65 2d 69 6e 63 2e  de "archive-inc.
1000: 73 63 6d 22 29 0a 28 69 6e 63 6c 75 64 65 20 22  scm").(include "
1010: 63 6c 69 65 6e 74 2d 69 6e 63 2e 73 63 6d 22 29  client-inc.scm")
1020: 0a 28 69 6e 63 6c 75 64 65 20 22 63 6f 6d 6d 6f  .(include "commo
1030: 6e 2d 69 6e 63 2e 73 63 6d 22 29 0a 28 69 6e 63  n-inc.scm").(inc
1040: 6c 75 64 65 20 22 64 62 2d 69 6e 63 2e 73 63 6d  lude "db-inc.scm
1050: 22 29 0a 28 69 6e 63 6c 75 64 65 20 22 64 63 6f  ").(include "dco
1060: 6d 6d 6f 6e 2d 69 6e 63 2e 73 63 6d 22 29 0a 28  mmon-inc.scm").(
1070: 69 6e 63 6c 75 64 65 20 22 64 61 73 68 62 6f 61  include "dashboa
1080: 72 64 2d 74 65 73 74 73 2d 69 6e 63 2e 73 63 6d  rd-tests-inc.scm
1090: 22 29 0a 28 69 6e 63 6c 75 64 65 20 22 65 6e 76  ").(include "env
10a0: 2d 69 6e 63 2e 73 63 6d 22 29 0a 28 69 6e 63 6c  -inc.scm").(incl
10b0: 75 64 65 20 22 65 7a 73 74 65 70 73 2d 69 6e 63  ude "ezsteps-inc
10c0: 2e 73 63 6d 22 29 0a 28 69 6e 63 6c 75 64 65 20  .scm").(include 
10d0: 22 67 75 74 69 6c 73 2d 69 6e 63 2e 73 63 6d 22  "gutils-inc.scm"
10e0: 29 0a 28 69 6e 63 6c 75 64 65 20 22 68 74 74 70  ).(include "http
10f0: 2d 74 72 61 6e 73 70 6f 72 74 2d 69 6e 63 2e 73  -transport-inc.s
1100: 63 6d 22 29 0a 28 69 6e 63 6c 75 64 65 20 22 69  cm").(include "i
1110: 74 65 6d 73 2d 69 6e 63 2e 73 63 6d 22 29 0a 28  tems-inc.scm").(
1120: 69 6e 63 6c 75 64 65 20 22 6b 65 79 73 2d 69 6e  include "keys-in
1130: 63 2e 73 63 6d 22 29 0a 28 69 6e 63 6c 75 64 65  c.scm").(include
1140: 20 22 6c 61 75 6e 63 68 2d 69 6e 63 2e 73 63 6d   "launch-inc.scm
1150: 22 29 0a 28 69 6e 63 6c 75 64 65 20 22 6d 61 72  ").(include "mar
1160: 67 73 2d 69 6e 63 2e 73 63 6d 22 29 0a 28 69 6e  gs-inc.scm").(in
1170: 63 6c 75 64 65 20 22 6d 74 2d 69 6e 63 2e 73 63  clude "mt-inc.sc
1180: 6d 22 29 0a 28 69 6e 63 6c 75 64 65 20 22 6f 64  m").(include "od
1190: 73 2d 69 6e 63 2e 73 63 6d 22 29 0a 28 69 6e 63  s-inc.scm").(inc
11a0: 6c 75 64 65 20 22 70 67 64 62 2d 69 6e 63 2e 73  lude "pgdb-inc.s
11b0: 63 6d 22 29 0a 28 69 6e 63 6c 75 64 65 20 22 70  cm").(include "p
11c0: 6f 72 74 6c 6f 67 67 65 72 2d 69 6e 63 2e 73 63  ortlogger-inc.sc
11d0: 6d 22 29 0a 28 69 6e 63 6c 75 64 65 20 22 70 72  m").(include "pr
11e0: 6f 63 65 73 73 2d 69 6e 63 2e 73 63 6d 22 29 0a  ocess-inc.scm").
11f0: 28 69 6e 63 6c 75 64 65 20 22 72 6d 74 2d 69 6e  (include "rmt-in
1200: 63 2e 73 63 6d 22 29 0a 28 69 6e 63 6c 75 64 65  c.scm").(include
1210: 20 22 72 75 6e 63 6f 6e 66 69 67 2d 69 6e 63 2e   "runconfig-inc.
1220: 73 63 6d 22 29 0a 28 69 6e 63 6c 75 64 65 20 22  scm").(include "
1230: 72 75 6e 73 2d 69 6e 63 2e 73 63 6d 22 29 0a 28  runs-inc.scm").(
1240: 69 6e 63 6c 75 64 65 20 22 73 65 72 76 65 72 2d  include "server-
1250: 69 6e 63 2e 73 63 6d 22 29 0a 28 69 6e 63 6c 75  inc.scm").(inclu
1260: 64 65 20 22 73 75 62 72 75 6e 2d 69 6e 63 2e 73  de "subrun-inc.s
1270: 63 6d 22 29 0a 28 69 6e 63 6c 75 64 65 20 22 74  cm").(include "t
1280: 61 73 6b 73 2d 69 6e 63 2e 73 63 6d 22 29 0a 28  asks-inc.scm").(
1290: 69 6e 63 6c 75 64 65 20 22 74 64 62 2d 69 6e 63  include "tdb-inc
12a0: 2e 73 63 6d 22 29 0a 28 69 6e 63 6c 75 64 65 20  .scm").(include 
12b0: 22 74 65 73 74 73 2d 69 6e 63 2e 73 63 6d 22 29  "tests-inc.scm")
12c0: 0a 28 69 6e 63 6c 75 64 65 20 22 76 67 2d 69 6e  .(include "vg-in
12d0: 63 2e 73 63 6d 22 29 0a 3b 3b 20 28 69 6e 63 6c  c.scm").;; (incl
12e0: 75 64 65 20 22 6a 73 2d 70 61 74 68 2e 73 63 6d  ude "js-path.scm
12f0: 22 29 20 3b 3b 20 6d 6f 76 65 64 20 69 6e 74 6f  ") ;; moved into
1300: 20 69 6e 69 74 20 70 72 6f 63 65 64 75 72 65 20   init procedure 
1310: 69 6e 20 74 65 73 74 73 2d 69 6e 63 2e 73 63 6d  in tests-inc.scm
1320: 0a 0a 29 0a 3b 3b 20 68 74 74 70 2d 74 72 61 6e  ..).;; http-tran
1330: 73 70 6f 72 74 3a 73 65 72 76 65 72 2d 64 61 74  sport:server-dat
1340: 20 64 65 66 69 6e 69 74 69 6f 6e 20 6d 6f 76 65   definition move
1350: 64 20 74 6f 20 63 6f 6d 6d 6f 6e 5f 72 65 63 6f  d to common_reco
1360: 72 64 73 2e 73 63 6d 0a 3b 3b 20 62 75 6e 63 68  rds.scm.;; bunch
1370: 20 6f 66 20 73 6d 61 6c 6c 20 66 75 6e 63 74 69   of small functi
1380: 6f 6e 73 20 66 61 63 74 6f 72 65 64 20 6f 75 74  ons factored out
1390: 20 6f 66 20 73 65 6e 64 2d 72 65 63 65 69 76 65   of send-receive
13a0: 20 74 6f 20 6d 61 6b 65 20 64 65 62 75 67 20 65   to make debug e
13b0: 61 73 69 65 72 0a                                asier.