-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathsimplifying-traversal.lisp
112 lines (92 loc) · 3.96 KB
/
simplifying-traversal.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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
#+xcvb (module (:depends-on ("dependencies-interpreter" "traversal")))
(in-package :xcvb)
#|
This provides a simplifying traversal that conflates all kind of dependencies
into just one kind. Used by non-enforcing backends such as the ASDF backend
and the non-enforcing Makefile backend.
|#
(defclass simplifying-traversal (traversal)
())
(defmethod linking-traversal-p ((env simplifying-traversal))
(declare (ignorable env))
nil)
(defmethod issue-build-command ((env simplifying-traversal) command)
(declare (ignorable env command))
(values))
(defmethod issue-dependency ((env simplifying-traversal) (grain fasl-grain))
(issue-dependency env (graph-for env `(:lisp ,(second (fullname grain))))))
(defmethod issue-dependency ((env simplifying-traversal) (grain cfasl-grain))
(issue-dependency env (graph-for env `(:lisp ,(second (fullname grain))))))
(defmethod issue-dependency ((env simplifying-traversal) (grain lisp-object-grain))
(issue-dependency env (graph-for env `(:lisp ,(second (fullname grain))))))
(define-build-command-for :lisp ((env simplifying-traversal) name)
(build-command-for-fasl env name))
(defmethod tweak-dependency ((env simplifying-traversal) dep)
(declare (ignorable env))
(if (not (consp dep))
dep
(case (first dep)
((:lisp) dep)
((:fasl) dep) ;; somehow we depend on that. TODO: simplify further
((:cfasl :link-object) `(:fasl ,(second dep)))
(t dep))))
(defmethod graph-for-build-module-grain ((env simplifying-traversal) grain)
(build-command-for* env (build-dependencies grain))
(build-command-for* env (compile-dependencies grain))
(build-command-for* env (cload-dependencies grain))
(build-command-for* env (load-dependencies grain))
nil)
(define-graph-for :fasl ((env simplifying-traversal) name)
(check-type name string)
(let ((grain (resolve-absolute-module-name name)))
(check-type grain lisp-file-grain)
(finalize-grain grain)
(issue-dependency env grain)
(let* ((dependencies
(remove-duplicates
(append (build-dependencies grain)
(let ((generator (grain-generator grain)))
(when generator (generator-dependencies generator)))
(compile-dependencies grain)
(cload-dependencies grain)
(load-dependencies grain))
:test 'equal :from-end t))
(fasl
(make-grain 'fasl-grain :fullname `(:fasl ,name)
:load-dependencies ())))
(build-command-for* env dependencies)
(make-computation
()
:outputs (list fasl)
:inputs ;(remove-if-not #'lisp-file-grain-p
(traversed-dependencies env) ;)
:command nil)
fasl)))
(define-graph-for :lisp ((env simplifying-traversal) name)
(finalize-grain (resolve-absolute-module-name name)))
(defvar *asdf-system-dependencies* nil
"A list of asdf system we depend upon")
#|(define-graph-for :asdf ((env simplifying-traversal) system-name)
(pushnew system-name *asdf-system-dependencies* :test 'equal)
nil)|#
(defvar *require-dependencies* nil
"A list of require features we depend upon")
(define-build-command-for :asdf ((env simplifying-traversal) name)
(pushnew name *asdf-system-dependencies* :test 'equal)
(values))
#|(define-graph-for :require ((env simplifying-traversal) name)
(pushnew name *require-dependencies* :test 'equal)
nil)
|#
(define-build-command-for :require ((env simplifying-traversal) name)
(pushnew name *require-dependencies* :test 'equal)
(values))
(defmethod run-generator ((env simplifying-traversal) (generator lisp-generator))
(let* ((dependencies (generator-dependencies generator))
(targets (generator-targets generator)))
(unless targets
(error "no targets"))
(unless dependencies
(error "run-generator: Need dependencies to generate files ~S.~%"
(mapcar #'fullname targets)))
(build-command-for* env dependencies)))