-
Notifications
You must be signed in to change notification settings - Fork 39
/
Copy pathpaths.rkt
42 lines (35 loc) · 1.35 KB
/
paths.rkt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
#lang racket
(provide output-dir
misclass-file-name dispute-file-name cleared-file-name problem-file-name
misclass-link dispute-link cleared-link problem-link
build-notes-link)
(define output-dir "data")
;; Note: output goes to a output subdir, so the link doesn't need to include it
;; (because it's automatically the base directory) whereas the check in the
;; filesystem needs to include it (because it's not).
(define (make-link sub-paths file-name)
(cond
[(empty? sub-paths) file-name]
[(cons? sub-paths)
(string-append (first sub-paths) "/"
(make-link (rest sub-paths) file-name))]))
(define (misclass-link path)
(make-link path "misclass.txt"))
(define (dispute-link path)
(make-link path "dispute.txt"))
(define (cleared-link path)
(make-link path "cleared.txt"))
(define (problem-link path)
(make-link path "problem.txt"))
(define (build-notes-link path)
(make-link path "build_notes.txt"))
(define (make-file-name path file)
(apply build-path (cons output-dir (append path (list file)))))
(define (misclass-file-name path)
(make-file-name path "misclass.txt"))
(define (dispute-file-name path)
(make-file-name path "dispute.txt"))
(define (cleared-file-name path)
(make-file-name path "cleared.txt"))
(define (problem-file-name path)
(make-file-name path "problem.txt"))