3 (define (set-int K V) (set K (int V 0 10)))
6 (map (curry set-int K) (clean empty? (parse V "\\s*,?\\s*" 0))))
9 (map (curry set K) (clean empty? (parse V "\\s*,?\\s*" 0))))
12 'FILE "hourglass.conf"
14 ("listener.ports" set-ints)
16 ("listener.activity.dir" set)
19 ("control.action" set)
22 ("control.extra.dat" set)
23 ("control.usage.dat" set)
24 ("control.usage.tmp" set)
25 ("control.activity.gap" set-int)
26 ("control.activity.clip" set)
39 (define (setting LINE)
40 (when (regex "^\\s([^;#][^=]*)=(.*)" LINE 0)
41 (let ((KV (map trim (list $1 $2))))
42 (if (lookup (KV 0) KEYS) (apply $it (list (sym (KV 0)) (KV 1)))))))
44 (map setting (parse (or (read-file FILE) "") "\n"))