X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~mdw/git/profile/blobdiff_plain/6b440e3f1a67b73bb35b1469f18065d18aa5402e..266c56a3de4186c495e20fdba2c4aa2473d029c4:/dot/lisp-init.lisp diff --git a/dot/lisp-init.lisp b/dot/lisp-init.lisp index 6624c60..ed6acd1 100644 --- a/dot/lisp-init.lisp +++ b/dot/lisp-init.lisp @@ -3,14 +3,56 @@ (defpackage #:mdw-hacks (: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. +#+cmu (ext:clear-search-list "HOME") +#+(and unix (or sbcl clisp cmu)) +(let* ((#1=#:homestring (or #+sbcl (sb-ext:posix-getenv "HOME") + #+clisp (ext:getenv "HOME") + #+cmu (unix:unix-getenv "HOME") + "/home/mdw")) + (#2=#:home (pathname (concatenate 'string #1# "/")))) + (setf (logical-pathname-translations "HOME") + `(("HOME:**;*.*.*" ,(merge-pathnames "**/*.*" #2# nil))) + (logical-pathname-translations "CL") + '(("CL:SOURCE;**;*.*.*" #p"/usr/share/common-lisp/source/**/*.*") + ("CL:SYSTEMS;**;*.*.*" #p"/usr/share/common-lisp/systems/**/*.*")))) + ;; 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")))