forked from shriram/repro-in-cs
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathstructure-data.rkt
46 lines (39 loc) · 1.69 KB
/
structure-data.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
43
44
45
46
#lang racket
(require "paths.rkt")
(provide convert-to-struct strip-header)
(provide (struct-out paper))
(struct raw-paper (group authors title practical
article/google email-sent email-reply
build-results database-entry build-notes)
#:transparent)
(struct paper (group authors title path builds? dispute? cleared? problem?)
#:transparent)
(define (strip-header l)
(rest l))
(define (split-into-sub-paths-strip.txt prefix s)
(and s
(regexp-split #rx"_"
(second
(regexp-match
(regexp (string-append "data/(.*)_" prefix ".txt"))
s)))))
;; Note: the "." in ".txt" above should be quoted: we mean the literal dot,
;; not the regexp for any ol' character. Maybe the "_" too. Regexps. Hunoz. WAT.
(define (convert-to-struct l)
(map (lambda (rp)
(let ([path (split-into-sub-paths-strip.txt "build" (raw-paper-build-notes rp))])
(paper (raw-paper-group rp) (raw-paper-authors rp) (raw-paper-title rp)
path
(let ([rpbr (raw-paper-build-results rp)])
(cond [(string=? rpbr "Builds") true]
[(string=? rpbr "Build fails") false]
[else (error 'wrong-build-entry "~a" path)]))
(file-exists? (dispute-file-name path))
(file-exists? (cleared-file-name path))
(file-exists? (problem-file-name path)))))
(map (lambda (p)
(apply raw-paper
(map (lambda (s)
(if (string=? s "-") false s))
p)))
l)))