Megatest

Hex Artifact Content
Login

Artifact 4dece87b4e3289ec012db69f44ddc6b28e352c70:


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 72 65 61 64  ========.;; read
0050: 20 61 20 63 6f 6e 66 69 67 20 66 69 6c 65 2c 20   a config file, 
0060: 6c 6f 61 64 69 6e 67 20 6f 6e 6c 79 20 74 68 65  loading only the
0070: 20 73 65 63 74 69 6f 6e 20 70 65 72 74 69 6e 65   section pertine
0080: 6e 74 0a 3b 3b 20 74 6f 20 74 68 69 73 20 72 75  nt.;; to this ru
0090: 6e 20 66 69 65 6c 64 31 76 61 6c 2f 66 69 65 6c  n field1val/fiel
00a0: 64 32 76 61 6c 2f 66 69 65 6c 64 33 76 61 6c 20  d2val/field3val 
00b0: 2e 2e 2e 0a 3b 3b 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ....;;==========
00c0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
00d0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
00e0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d  ================
00f0: 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 3d 0a 28 64 65  ============.(de
0100: 66 69 6e 65 20 28 73 65 74 75 70 2d 65 6e 76 2d  fine (setup-env-
0110: 64 65 66 61 75 6c 74 73 20 64 62 20 66 6e 61 6d  defaults db fnam
0120: 65 20 72 75 6e 2d 69 64 20 2e 20 61 6c 72 65 61  e run-id . alrea
0130: 64 79 2d 73 65 65 6e 29 0a 20 20 28 6c 65 74 2a  dy-seen).  (let*
0140: 20 28 28 6b 65 79 73 20 20 20 20 28 67 65 74 2d   ((keys    (get-
0150: 6b 65 79 73 20 64 62 29 29 0a 09 20 28 6b 65 79  keys db)).. (key
0160: 76 61 6c 73 20 28 67 65 74 2d 6b 65 79 2d 76 61  vals (get-key-va
0170: 6c 73 20 64 62 20 72 75 6e 2d 69 64 29 29 0a 09  ls db run-id))..
0180: 20 28 74 68 65 6b 65 79 20 20 28 73 74 72 69 6e   (thekey  (strin
0190: 67 2d 69 6e 74 65 72 73 70 65 72 73 65 20 28 6d  g-intersperse (m
01a0: 61 70 20 28 6c 61 6d 62 64 61 20 28 78 29 28 69  ap (lambda (x)(i
01b0: 66 20 78 20 78 20 22 2d 6e 61 2d 22 29 29 20 6b  f x x "-na-")) k
01c0: 65 79 76 61 6c 73 29 20 22 2f 22 29 29 0a 09 20  eyvals) "/")).. 
01d0: 28 63 6f 6e 66 64 61 74 20 28 72 65 61 64 2d 63  (confdat (read-c
01e0: 6f 6e 66 69 67 20 66 6e 61 6d 65 20 23 66 20 23  onfig fname #f #
01f0: 66 29 29 0a 09 20 28 77 68 61 74 66 6f 75 6e 64  f)).. (whatfound
0200: 20 28 6d 61 6b 65 2d 68 61 73 68 2d 74 61 62 6c   (make-hash-tabl
0210: 65 29 29 0a 09 20 28 73 65 63 74 69 6f 6e 73 20  e)).. (sections 
0220: 28 6c 69 73 74 20 22 64 65 66 61 75 6c 74 22 20  (list "default" 
0230: 74 68 65 6b 65 79 29 29 29 0a 20 20 20 20 28 64  thekey))).    (d
0240: 65 62 75 67 3a 70 72 69 6e 74 20 34 20 22 55 73  ebug:print 4 "Us
0250: 69 6e 67 20 6b 65 79 3d 5c 22 22 20 74 68 65 6b  ing key=\"" thek
0260: 65 79 20 22 5c 22 22 29 0a 20 20 20 20 28 66 6f  ey "\"").    (fo
0270: 72 2d 65 61 63 68 20 0a 20 20 20 20 20 28 6c 61  r-each .     (la
0280: 6d 62 64 61 20 28 73 65 63 74 69 6f 6e 29 0a 20  mbda (section). 
0290: 20 20 20 20 20 20 28 6c 65 74 20 28 28 73 65 63        (let ((sec
02a0: 74 69 6f 6e 2d 64 61 74 20 28 68 61 73 68 2d 74  tion-dat (hash-t
02b0: 61 62 6c 65 2d 72 65 66 2f 64 65 66 61 75 6c 74  able-ref/default
02c0: 20 63 6f 6e 66 64 61 74 20 73 65 63 74 69 6f 6e   confdat section
02d0: 20 23 66 29 29 29 0a 09 20 28 69 66 20 73 65 63   #f))).. (if sec
02e0: 74 69 6f 6e 2d 64 61 74 0a 09 20 20 20 20 20 28  tion-dat..     (
02f0: 66 6f 72 2d 65 61 63 68 20 0a 09 20 20 20 20 20  for-each ..     
0300: 20 28 6c 61 6d 62 64 61 20 28 65 6e 76 76 61 72   (lambda (envvar
0310: 29 0a 09 09 28 68 61 73 68 2d 74 61 62 6c 65 2d  )...(hash-table-
0320: 73 65 74 21 20 77 68 61 74 66 6f 75 6e 64 20 73  set! whatfound s
0330: 65 63 74 69 6f 6e 20 28 2b 20 28 68 61 73 68 2d  ection (+ (hash-
0340: 74 61 62 6c 65 2d 72 65 66 2f 64 65 66 61 75 6c  table-ref/defaul
0350: 74 20 77 68 61 74 66 6f 75 6e 64 20 73 65 63 74  t whatfound sect
0360: 69 6f 6e 20 30 29 20 31 29 29 0a 09 09 28 73 65  ion 0) 1))...(se
0370: 74 65 6e 76 20 65 6e 76 76 61 72 20 28 63 61 64  tenv envvar (cad
0380: 72 20 28 61 73 73 6f 63 20 65 6e 76 76 61 72 20  r (assoc envvar 
0390: 73 65 63 74 69 6f 6e 2d 64 61 74 29 29 29 29 0a  section-dat)))).
03a0: 09 20 20 20 20 20 20 28 6d 61 70 20 63 61 72 20  .      (map car 
03b0: 73 65 63 74 69 6f 6e 2d 64 61 74 29 29 29 29 29  section-dat)))))
03c0: 0a 20 20 20 20 20 73 65 63 74 69 6f 6e 73 29 0a  .     sections).
03d0: 20 20 20 20 28 69 66 20 28 61 6e 64 20 28 6e 6f      (if (and (no
03e0: 74 20 28 6e 75 6c 6c 3f 20 61 6c 72 65 61 64 79  t (null? already
03f0: 2d 73 65 65 6e 29 29 0a 09 20 20 20 20 20 28 6e  -seen))..     (n
0400: 6f 74 20 28 63 61 72 20 61 6c 72 65 61 64 79 2d  ot (car already-
0410: 73 65 65 6e 29 29 29 0a 09 28 62 65 67 69 6e 0a  seen)))..(begin.
0420: 09 20 20 28 64 65 62 75 67 3a 70 72 69 6e 74 20  .  (debug:print 
0430: 32 20 22 4b 65 79 20 73 65 74 74 69 6e 67 73 20  2 "Key settings 
0440: 66 6f 75 6e 64 20 69 6e 20 72 75 6e 63 6f 6e 66  found in runconf
0450: 69 67 2e 63 6f 6e 66 69 67 3a 22 29 0a 09 20 20  ig.config:")..  
0460: 28 66 6f 72 2d 65 61 63 68 20 28 6c 61 6d 62 64  (for-each (lambd
0470: 61 20 28 66 75 6c 6c 6b 65 79 29 0a 09 09 20 20  a (fullkey)...  
0480: 20 20 20 20 28 64 65 62 75 67 3a 70 72 69 6e 74      (debug:print
0490: 20 32 20 28 66 6f 72 6d 61 74 20 23 66 20 22 7e   2 (format #f "~
04a0: 32 30 61 20 7e 61 5c 6e 22 20 66 75 6c 6c 6b 65  20a ~a\n" fullke
04b0: 79 20 28 68 61 73 68 2d 74 61 62 6c 65 2d 72 65  y (hash-table-re
04c0: 66 2f 64 65 66 61 75 6c 74 20 77 68 61 74 66 6f  f/default whatfo
04d0: 75 6e 64 20 66 75 6c 6c 6b 65 79 20 30 29 29 29  und fullkey 0)))
04e0: 29 0a 09 09 20 20 20 20 73 65 63 74 69 6f 6e 73  )...    sections
04f0: 29 0a 09 20 20 28 64 65 62 75 67 3a 70 72 69 6e  )..  (debug:prin
0500: 74 20 32 20 22 2d 2d 2d 22 29 0a 09 20 20 28 73  t 2 "---")..  (s
0510: 65 74 21 20 2a 61 6c 72 65 61 64 79 2d 73 65 65  et! *already-see
0520: 6e 2d 72 75 6e 63 6f 6e 66 69 67 2d 69 6e 66 6f  n-runconfig-info
0530: 2a 20 23 74 29 29 29 29 29 0a 0a 28 64 65 66 69  * #t)))))..(defi
0540: 6e 65 20 28 73 65 74 2d 72 75 6e 2d 63 6f 6e 66  ne (set-run-conf
0550: 69 67 2d 76 61 72 73 20 64 62 20 72 75 6e 2d 69  ig-vars db run-i
0560: 64 29 0a 20 20 28 6c 65 74 20 28 28 72 75 6e 63  d).  (let ((runc
0570: 6f 6e 66 69 67 66 20 28 63 6f 6e 63 20 20 2a 74  onfigf (conc  *t
0580: 6f 70 70 61 74 68 2a 20 22 2f 72 75 6e 63 6f 6e  oppath* "/runcon
0590: 66 69 67 73 2e 63 6f 6e 66 69 67 22 29 29 29 0a  figs.config"))).
05a0: 20 20 20 20 28 69 66 20 28 66 69 6c 65 2d 65 78      (if (file-ex
05b0: 69 73 74 73 3f 20 72 75 6e 63 6f 6e 66 69 67 66  ists? runconfigf
05c0: 29 0a 09 28 73 65 74 75 70 2d 65 6e 76 2d 64 65  )..(setup-env-de
05d0: 66 61 75 6c 74 73 20 64 62 20 72 75 6e 63 6f 6e  faults db runcon
05e0: 66 69 67 66 20 72 75 6e 2d 69 64 29 0a 09 28 64  figf run-id)..(d
05f0: 65 62 75 67 3a 70 72 69 6e 74 20 30 20 22 57 41  ebug:print 0 "WA
0600: 52 4e 49 4e 47 3a 20 59 6f 75 20 64 6f 20 6e 6f  RNING: You do no
0610: 74 20 68 61 76 65 20 61 20 72 75 6e 20 63 6f 6e  t have a run con
0620: 66 69 67 20 66 69 6c 65 3a 20 22 20 72 75 6e 63  fig file: " runc
0630: 6f 6e 66 69 67 66 29 29 29 29 0a 20 20           onfigf)))).