-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathblog.lisp
67 lines (63 loc) · 2.3 KB
/
blog.lisp
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
(defun blog-1 ()
(let ((p `(,@+lib-list+
(defvar main
(let ((primes (cons 2 (cons 3 (cons 5 nil)))))
(map (+ (+ 1 1)) primes))))))
(in-fresh-context
(let ((g (parse-program p)))
(with-open-file (s "graph-01-app.dot" :direction :output :if-exists :supersede)
(dot-from-graph g s))
(simplify-apps g)
(with-open-file (s "graph-01.dot" :direction :output :if-exists :supersede)
(dot-from-graph g s))
(reduce-to-whnf g)
(with-open-file (s "graph-01-map-reduced.dot" :direction :output :if-exists :supersede)
(dot-from-graph g s))
g))))
(defun blog-2 ()
(let ((p `(,@+lib-list+
(defvar nats (cons 0 (map + 1) nats))
(defvar main nats))))
(in-fresh-context
(let ((g (parse-program p])))
(simplify-apps g)
(with-open-file (s "graph-02.dot" :direction :output :if-exists :supersede)
(dot-from-graph g s))
(reduce-to-whnf (nth 1 (gnode-args (gderef g))))
(with-open-file (s "graph-02-tail.dot" :direction :output :if-exists :supersede)
(dot-from-graph g s))
g))))
(defun blog-3 ()
(let ((p `(,@+lib-list+
(defvar main
(let ((zig (cons 0 zag))
(zag (cons 1 zig)))
zig)))))
(in-fresh-context
(let ((g (parse-program p)))
(simplify-apps g)
(with-open-file (s "graph-03.dot" :direction :output :if-exists :supersede)
(dot-from-graph g s))
g))))
(defun blog-4 ()
(let ((p `(,@+lib-list+
(defvar main
(let ((xs xs))
(cons 1 xs))))))
(in-fresh-context
(let ((g (parse-program p)))
(simplify-apps g)
(with-open-file (s "graph-03-bottom.dot" :direction :output :if-exists :supersede)
(dot-from-graph g s))
g))))
(defun hello ()
(let ((p `((defvar main (string-append "Hello, " "world!")))))
(in-fresh-context
(let ((g (parse-program p)))
(simplify-apps g)
(with-open-file (s "hello.dot" :direction :output :if-exists :supersede)
(dot-from-graph g s))
(reduce-to-whnf g)
(with-open-file (s "hello-reduced.dot" :direction :output :if-exists :supersede)
(dot-from-graph g s))
g))))