X-Git-Url: https://git.distorted.org.uk/~mdw/profile/blobdiff_plain/9906310798d936a6cacd0ec5a2d3b607e911c423..c4e34468df5e5ee2b5f5faef734056aadb967c38:/dot/lisp-init.lisp diff --git a/dot/lisp-init.lisp b/dot/lisp-init.lisp index 8da623d..fdb2229 100644 --- a/dot/lisp-init.lisp +++ b/dot/lisp-init.lisp @@ -3,14 +3,55 @@ (:export #:crank-swank)) (use-package '#:mdw-hacks) +;; Obtain ASDF from somewhere. +#+sbcl (require :asdf) +#+clisp (let ((*compile-verbose* nil) + (*load-verbose* nil)) + (handler-bind ((warning (lambda (cond) + (declare (ignore cond)) + (muffle-warning)))) + (load "/usr/share/common-lisp/source/cl-asdf/asdf.lisp" + :verbose nil) + (funcall (find-symbol "LOAD-SYSTEM" :asdf) :asdf + :verbose nil))) + ;; Shut up. (setf *load-verbose* nil) (setf *compile-verbose* nil) #+cmu (setf *gc-verbose* nil) +;; Tell SBCL where to find its source source. +#+sbcl +(let ((#1=#:sbcl-src #p"/usr/share/sbcl-source/")) + (flet ((#2=#:sbcl-dir (#3=#:p) + (merge-pathnames #3# #1#))) + (setf (logical-pathname-translations "SYS") + `(("SYS:SRC;**;*.*.*" ,(#2# "src/**/*.*")) + ("SYS:CONTRIB;**;*.*.*" ,(#2# "contrib/**/*.*")))))) + +;; Tell some Lisps about my home directory. +#+sbcl (require :sb-posix) +#+cmu (ext:clear-search-list "HOME") +#+(and unix (or sbcl clisp cmu)) +(let ((#1=#:home (pathname (concatenate 'string + (or #+sbcl (sb-posix:getenv "HOME") + #+clisp (ext:getenv "HOME") + #+cmu (unix:unix-getenv "HOME") + "/home/mdw") + "/")))) + (setf (logical-pathname-translations "HOME") + `(("HOME:**;*.*.*" ,(merge-pathnames "**/*.*" #1# nil))))) + ;; Various fixings. #+clisp (setf custom:*parse-namestring-ansi* t) +;; Shebang. +(set-dispatch-macro-character + #\# #\! + (lambda (#1=#:stream . #2=(#:char #:arg)) + (declare (ignore . #2#)) + (values (read-line #1#)))) + ;; Start up swank. (defun mdw-hacks:crank-swank (&rest #1=#:args) (let ((#2=#:swank #3=(find-package "SWANK"))) @@ -20,6 +61,8 @@ (set (find-symbol "*GLOBAL-DEBUGGER*" #2#) nil) (apply (find-symbol "CREATE-SERVER" #2#) #1#))) +#+asdf (setf asdf:*compile-file-failure-behaviour* :warn) + ;; Done. (pushnew :mdw *features*) ;;#+(and cmu mp) (mp::startup-idle-and-top-level-loops)