X-Git-Url: https://git.distorted.org.uk/~mdw/runlisp/blobdiff_plain/82cc08353498d235b64d63baadabf84c28d3e2e2..35f7e5a0bf3d4fd5984e3ef3d8daf91417eff6e4:/dump-ecl diff --git a/dump-ecl b/dump-ecl index 4ec27b4..924009e 100755 --- a/dump-ecl +++ b/dump-ecl @@ -33,6 +33,25 @@ run () { echo "$*"; "$@"; } cat >"$tmp/ecl-build.lisp" <<'EOF' (require "asdf") +;; Defeat ASDF's built-in knowledge of itself. If we've just loaded the most +;; up-to-date version of ASDF then it won't bother loading the system +;; definition from disk which knows about the actual source files. And if it +;; doesn't think it has any source files then it won't compile anything. +(asdf:load-asd + (funcall (let* ((cache-pkg (find-package "ASDF/CACHE")) + (session-pkg (find-package "ASDF/SESSION"))) + (symbol-function + (cond (cache-pkg + (find-symbol "CALL-WITH-ASDF-CACHE" cache-pkg)) + (session-pkg + (find-symbol "CALL-WITH-ASDF-SESSION" session-pkg)) + (t + (error "I don't know how to hack this version of ASDF: ~ + please report this as a bug."))))) + (lambda () + (asdf:search-for-system-definition "asdf"))) + :name "asdf") + (defparameter *asdf* (asdf:find-system "asdf") "The `asdf' system itself.")