1 ;; FIXME: arrange packages so that this can be moved in ASDF some time later?
3 (in-package #:cffi-toolchain
)
5 (defun static-ops-enabled-p ()
6 (ensure-toolchain-parameters)
7 (and (or *linkkit-start
* *linkkit-end
*) t
))
9 (defclass static-runtime-op
(monolithic-bundle-op link-op selfward-operation
)
10 ((selfward-operation :initform
'monolithic-lib-op
:allocation
:class
))
11 (:documentation
"Create a Lisp runtime linkable library for the system and its dependencies."))
13 (defmethod output-files ((o static-runtime-op
) (s system
))
15 (list (subpathname (component-pathname s
)
16 (strcat (coerce-name s
) "-runtime")
17 :type
(bundle-pathname-type :program
))))
19 (defmethod perform ((o static-runtime-op
) (s system
))
22 (link-all-library (first (input-files o s
)))))
24 (defclass static-image-op
(image-op)
25 (#-
(or ecl mkcl
) (selfward-operation :initform
'(load-op static-runtime-op
) :allocation
:class
)
27 (gather-operation :initform
'compile-op
:allocation
:class
)
29 (gather-type :initform
:object
:allocation
:class
))
30 (:documentation
"Create a statically linked standalone image for the system."))
32 (defclass static-program-op
(program-op static-image-op
)
33 (#-
(or ecl mkcl
) (selfward-operation :initform
'(load-op static-runtime-op
) :allocation
:class
)
35 (gather-operation :initform
'compile-op
:allocation
:class
)
37 (gather-type :initform
:object
:allocation
:class
))
38 (:documentation
"Create a statically linked standalone executable for the system."))
40 ;; Problem? Its output may conflict with the program-op output :-/
43 (defmethod perform ((o static-image-op
) (s system
))
44 #-
(or clisp sbcl
) (error "Not implemented yet")
46 (let* ((name (coerce-name s
))
47 (runtime (output-file 'static-runtime-op s
))
49 #+clisp
(implementation-file "base/lispinit.mem")
50 #+sbcl
(subpathname (lisp-implementation-directory) "sbcl.core"))
51 (output (output-file o s
))
52 (child-op (if (typep o
'program-op
) 'program-op
'image-op
)))
53 (with-temporary-output (tmp output
)
54 (apply 'invoke runtime
55 #+clisp
"-M" #+sbcl
"--core" image
56 `(#+clisp
,@'("--silent" "-ansi" "-norc" "-x")
57 #+sbcl
,@'("--noinform" "--non-interactive" "--no-sysinit" "--no-userinit" "--eval")
58 ,(with-safe-io-syntax (:package
:asdf
)
59 (let ((*print-pretty
* nil
)
60 (*print-case
* :downcase
))
62 ;; This clever staging allows to put things in a single form,
63 ;; as required for CLISP not to print output for the first form,
64 ;; yet allow subsequent forms to rely on packages defined by former forms.
69 ,@(if-let (ql-home (find-symbol* :*quicklisp-home
* :ql-setup nil
))
70 `((load ,(subpathname (symbol-value ql-home
) "setup.lisp"))))
71 (setf asdf
:*central-registry
* ',asdf
:*central-registry
*)
72 (initialize-source-registry ',asdf
::*source-registry-parameter
*)
73 (initialize-output-translations ',asdf
::*output-translations-parameter
*)
74 (load-system "cffi-grovel")
75 ;; We force the operation to take place
76 (defmethod operation-done-p
77 ((operation ,child-op
) (system (eql (find-system ,name
))))
79 ;; Some implementations (notably SBCL) die as part of dumping an image,
80 ;; so redirect output-files to desired destination, for this processs might
81 ;; never otherwise get a chance to move the file to destination.
82 (defmethod output-files
83 ((operation ,child-op
) (system (eql (find-system ,name
))))
84 (values (list ,tmp
) t
))
85 (operate ',child-op
,name
)
89 (defmethod perform ((o static-image-op
) (s system
))
92 (format nil
"-Wl,--export-dynamic ~@[ ~A~]"
96 ;; Allow for :static-FOO-op in ASDF definitions.
97 (setf (find-class 'asdf
::static-runtime-op
) (find-class 'static-runtime-op
)
98 (find-class 'asdf
::static-image-op
) (find-class 'static-image-op
)
99 (find-class 'asdf
::static-program-op
) (find-class 'static-program-op
))