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"
15 ("listener.ports" set-ints)
17 ("listener.activity.dir" set)
18 ("control.action" set)
21 ("control.extra.dat" set)
22 ("control.usage.dat" set)
23 ("control.usage.tmp" set)
30 (define (setting LINE)
31 (when (regex "^\\s([^;#][^=]*)=(.*)" LINE 0)
32 (let ((KV (map trim (list $1 $2))))
33 (if (lookup (KV 0) KEYS) (apply $it (list (sym (KV 0)) (KV 1)))))))
35 (map setting (parse (or (read-file FILE) "") "\n"))