(let ((arg (first (ext:command-args)))) (mapc (lambda (name feature) (when (search name arg) (pushnew feature *features*))) (list "/ecl-android/" "/ecl-ios/") (list :android :ios))) (require :asdf) (push (merge-pathnames "../") asdf:*central-registry*) (setf *default-pathname-defaults* (truename (merge-pathnames "../../../"))) ; LQML root (defvar *current* (let ((name (namestring *load-truename*))) (subseq name (length (namestring *default-pathname-defaults*)) (position #\/ name :from-end t)))) ;; load all LQML symbols (dolist (file (list "package" "x" "ecl-ext" "ini" "qml")) (load (merge-pathnames file "src/lisp/"))) (defun cc (&rest args) (apply 'concatenate 'string args)) #-(or android ios) (progn (asdf:make-build "app" :monolithic t :type :static-library :move-here (cc *current* "/build/tmp/") :init-name "ini_app") (let* ((from (cc *current* "/build/tmp/app--all-systems.a")) (to "libapp.a") (to* (cc *current* "/build/tmp/" to))) (when (probe-file to*) (delete-file to*)) (rename-file from to))) #+(or android ios) (progn (defvar *asdf-system* "app") (defvar *ql-libs* (cc *current* "/ql-libs.lisp")) (defvar *init-name* "ini_app") (defvar *library-name* (cc *current* (format nil "/build-~A/tmp/app" #+android "android" #+ios "ios"))) (defvar *epilogue-code* nil) (load "platforms/shared/make"))