-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathprogram.lisp
33 lines (27 loc) · 1.47 KB
/
program.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
(defun partition-by (f xs)
(let ((table (make-hash-table)))
(loop for x in xs
for key = (funcall f x)
do (push x (gethash key table)))
(maphash (lambda (key group) (setf (gethash key table) (reverse group))) table)
table))
(defun parse-program (program)
(let ((program-parts (partition-by #'first program)))
(add-constructors
(loop for (defdata type-name type-args . constructors) in (gethash 'defdata program-parts)
append (loop for (cons-name . cons-args) in constructors
collect (cons cons-name type-name))))
(add-vars
(loop for (defvar var-name var-body) in (gethash 'defvar program-parts)
collect (cons var-name (normalize-expr var-body))))
(let ((fun-defs
(loop for (deffun name . matches) in (gethash 'deffun program-parts)
do (register-proto-function name (length (caar matches)))
collect (cons name (loop for (pats expr) in matches
collect (cons (mapcar #'normalize-pat pats) (normalize-expr expr)))))))
;; Build graphs for functions
(loop for (fun-name . matches) in fun-defs
for match-nodes = (loop for (pats . expr) in matches
collect (cons pats (fill-var-gref (graph-from-expr expr))))
do (register-match-function fun-name match-nodes)))
(fill-var-gref (graph-from-var 'main (cdr (assoc 'main *vars*))))))