forked from LuKuangChen/stacker-on-racket
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathshow.rkt
59 lines (57 loc) · 1.97 KB
/
show.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
53
54
55
56
57
58
59
#lang racket
;; input/output
(provide string-of-o)
(require "io.rkt")
(require (only-in plait some-v some?))
(define (string-of-o o)
(cond
[(o-exn? o)
"error"
#;(format "error: ~a" (o-exn-it o))]
[(o-con? o) (string-of-c (o-con-it o))]
[(o-vec? o) (format "'#(~a)" (string-join (vector->list (vector-map string-of-o-internal (o-vec-it o))) " "))]
[(o-list? o)
(let ([o (o-list-it o)])
(if (empty? o)
"'()"
(format "(list ~a)" (string-join (map string-of-o-internal o) " "))))]
[(o-fun? o)
(if (some? (o-fun-it o))
(format "~a" (some-v (o-fun-it o)))
"#<procedure>")
#;
(if (some? (o-fun-it o))
(format "#<procedure:~a>" (some-v (o-fun-it o)))
"#<procedure>")]
[(o-void? o) "#<void>"]
[(o-rec? o) (format "#~a=~a" (o-rec-id o) (string-of-o (o-rec-content o)))]
[(o-var? o) (format "#~a#" (o-var-id o))]
[else
(displayln o)
(displayln (o-rec? o))
(error 'show "internal error ~a" o)]))
(define (string-of-o-internal o)
(cond
[(o-exn? o)
"error"
#;(format "error: ~a" (o-exn-it o))]
[(o-con? o) (string-of-c (o-con-it o))]
[(o-vec? o) (format "#(~a)" (string-join (vector->list (vector-map string-of-o-internal (o-vec-it o))) " "))]
[(o-list? o) (format "(~a)" (string-join (map string-of-o-internal (o-list-it o)) " "))]
[(o-fun? o) "#<procedure>"]
[(o-void? o) "#<void>"]
[(o-rec? o) (format "#~a=~a" (o-rec-id o) (string-of-o-internal (o-rec-content o)))]
[(o-var? o) (format "#~a#" (o-var-id o))]
[else (error 'show "internal error ~a" o)]))
(define (string-of-c c)
(parameterize ([print-boolean-long-form #t])
(define p (open-output-string))
(write (pre-string-of-c c) p)
(get-output-string p)))
(define (pre-string-of-c c)
(cond
[(c-str? c) (c-str-it c)]
[(c-num? c) (c-num-it c)]
[(c-bool? c) (c-bool-it c)]
[(c-char? c) (c-char-it c)]
[else (error 'show "internal error ~a" c)]))