-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathtests-5.3-req.scm
52 lines (49 loc) · 1.5 KB
/
tests-5.3-req.scm
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
(add-tests-with-string-output "call/cc"
[(call/cc (lambda (k) 12)) => "12\n"]
[(call/cc (lambda (k) (k 12))) => "12\n"]
[(call/cc (lambda (k) (fx+ 1 (k 12)))) => "12\n"]
[(fx+ (call/cc (lambda (k) (k 12)))
(call/cc (lambda (k) 13))) => "25\n"]
[(letrec ([fact
(lambda (n k)
(cond
[(fxzero? n) (k 1)]
[else (fx* n (fact (fxsub1 n) k))]))])
(call/cc
(lambda (k)
(fact 5 k)))) => "1\n"]
[(call/cc
(lambda (k)
(letrec ([fact
(lambda (n)
(cond
[(fxzero? n) (k 1)]
[else (fx* n (fact (fxsub1 n)))]))])
(fact 5)))) => "1\n"]
[(let ([k #f])
(letrec ([fact
(lambda (n)
(cond
[(fxzero? n)
(call/cc
(lambda (nk)
(set! k nk)
(k 1)))]
[else (fx* n (fact (fxsub1 n)))]))])
(let ([v (fact 5)])
v))) => "120\n"]
[(let ([k #f])
(letrec ([fact
(lambda (n)
(cond
[(fxzero? n)
(call/cc
(lambda (nk)
(set! k nk)
(k 1)))]
[else (fx* n (fact (fxsub1 n)))]))])
(let ([v (fact 5)])
(let ([nk k])
(set! k (lambda (x) (cons v x)))
(nk v))))) => "(120 . 14400)\n"]
)