-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathinterp-Rwhile-proxy.rkt
92 lines (82 loc) · 3.49 KB
/
interp-Rwhile-proxy.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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
#lang racket
(require racket/fixnum)
(require "utilities.rkt")
(require "interp-Rwhile-prime.rkt")
(require (prefix-in runtime-config: "runtime-config.rkt"))
(provide interp-Rwhile-proxy interp-Rwhile-proxy-class)
(define interp-Rwhile-proxy-class
(class interp-Rwhile-prime-class
(super-new)
(inherit apply-fun initialize! interp-def interp-exp)
(define (guarded-vector-ref vec i)
(match vec
[`(vector-proxy ,proxy)
(define val (guarded-vector-ref (vector-ref proxy 0) i))
(define rd (vector-ref (vector-ref proxy 1) i))
(apply-fun rd (list val) 'guarded-vector-ref)]
[else (vector-ref vec i)]))
(define (guarded-vector-set! vec i arg)
(match vec
[`(vector-proxy ,proxy)
(define wr (vector-ref (vector-ref proxy 2) i))
(define arg^ (apply-fun wr (list arg) 'guarded-vector-set!))
(guarded-vector-set! (vector-ref proxy 0) i arg^)]
[else (vector-set! vec i arg)]))
(define (guarded-vector-length vec)
(match vec
[`(vector-proxy ,proxy)
(guarded-vector-length (vector-ref proxy 0))]
[else (vector-length vec)]))
(define/override (interp-op op)
(match op
['inject-vector (lambda (v) v)]
['inject-proxy (lambda (v) `(vector-proxy ,v))]
['proxy? (match-lambda
[`(vector-proxy ,v) #t]
[else #f])]
['project-vector (lambda (v) v)]
['proxy-vector-ref guarded-vector-ref]
['proxy-vector-set! guarded-vector-set!]
['proxy-vector-length guarded-vector-length]
['any-vector-ref (lambda (v i)
(match v [(Tagged v^ tg)
(guarded-vector-ref v^ i)]))]
['any-vector-set! (lambda (v i a)
(match v [(Tagged v^ tg)
(guarded-vector-set! v^ i a)]))]
['any-vector-length (lambda (v)
(match v [(Tagged v^ tg)
(guarded-vector-length v^)]))]
[else (super interp-op op)]))
(define/override (apply-project v ty2)
(define tag2 (any-tag ty2))
(match v
[(Tagged v1 tag1)
(cond [(eq? tag1 tag2)
(match ty2
[`(PVector ,ts ...)
(define len ((interp-op 'proxy-vector-length) v1))
(cond [(eq? len (length ts)) v1]
[else
(error 'apply-project
"incorrect vector length, ~a != ~a"
len (length ts))])]
[else (super apply-project v ty2)])]
[else (error 'apply-project "tag mismatch ~a != ~a" tag1 tag2)])]
[else (error 'apply-project "expected tagged value, not ~a" v)]))
(define/override (interp-program ast)
(match ast
;; Before shrink
[(ProgramDefsExp info ds body)
((initialize!) runtime-config:rootstack-size
runtime-config:heap-size)
(define top-level (for/list ([d ds]) (interp-def d)))
(for ([f (in-dict-values top-level)])
(set-box! f (match (unbox f)
[`(function ,xs ,body ())
`(function ,xs ,body ,top-level)])))
((interp-exp top-level) body)]
[else (super interp-program ast)]))
))
(define (interp-Rwhile-proxy p)
(send (new interp-Rwhile-proxy-class) interp-program p))