-
Notifications
You must be signed in to change notification settings - Fork 256
/
test.rkt
52 lines (42 loc) · 1.67 KB
/
test.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
47
48
49
50
51
52
#lang racket/base
(require racket/flonum racket/tcp racket/file racket/os racket/unsafe/ops json)
(#%declare #:unsafe)
(struct Coordinates (x y z) #:transparent)
(define (calc text)
(define jobj (bytes->jsexpr text))
(let-values ([(x y z len) (for/fold ([x 0.0]
[y 0.0]
[z 0.0]
[len 0])
([coord (hash-ref jobj 'coordinates)])
(values (unsafe-fl+ x (hash-ref coord 'x))
(unsafe-fl+ y (hash-ref coord 'y))
(unsafe-fl+ z (hash-ref coord 'z))
(unsafe-fx+ len 1)))])
(let ([len-fl (->fl len)])
(Coordinates (unsafe-fl/ x len-fl) (unsafe-fl/ y len-fl) (unsafe-fl/ z len-fl)))))
(define (notify msg)
(with-handlers ([exn:fail:network? void])
(let-values ([(in out) (tcp-connect "localhost" 9001)])
(display msg out)
(close-input-port in)
(close-output-port out))))
(define (verify)
(define right (Coordinates 2.0 0.5 0.25))
(for ([v '(#"{\"coordinates\":[{\"x\":2.0,\"y\":0.5,\"z\":0.25}]}"
#"{\"coordinates\":[{\"y\":0.5,\"x\":2.0,\"z\":0.25}]}")])
(define left (calc v))
(when (not (equal? left right))
(error 'verify "~s != ~s" left right))))
(define (read-c path)
(parameterize ([current-locale "C"])
(file->bytes path)))
(module+ test
(verify))
(module+ main
(verify)
(define text (read-c "/tmp/1.json"))
(notify (format "Racket\t~s" (getpid)))
(define results (calc text))
(notify "stop")
(displayln results))