-
Notifications
You must be signed in to change notification settings - Fork 70
/
interp-Lvecof.rkt
36 lines (32 loc) · 1.1 KB
/
interp-Lvecof.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
#lang racket
(require racket/fixnum)
(require "utilities.rkt")
(require "interp-Lvec.rkt")
(provide interp-Lvecof interp-Lvecof-class)
;; Note to maintainers of this code:
;; A copy of this interpreter is in the book and should be
;; kept in sync with this code.
(define interp-Lvecof-class
(class interp-Lvec-class
(super-new)
(define/override (interp-op op)
(verbose "Lvecof/interp-op" op)
(match op
['make-vector make-vector]
['vectorof-length vector-length]
['vectorof-ref
(lambda (v i)
(if (< i (vector-length v))
(vector-ref v i)
(error 'trapped-error "vectorof-ref: index ~a out of bounds\nin ~v" i v)))]
['vectorof-set!
(lambda (v i e)
(if (< i (vector-length v))
(vector-set! v i e)
(error 'trapped-error "vectorof-set!: index ~a out of bounds\nin ~v" i v)))]
['* fx*]
['exit (lambda () (error 'interp "exiting"))]
[else (super interp-op op)]))
))
(define (interp-Lvecof p)
(send (new interp-Lvecof-class) interp-program p))