dot/lisp-init.lisp: The logical-pathname translations don't work in Clisp.
[profile] / dot / lisp-init.lisp
index c77e494..e060815 100644 (file)
 (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/**/*.*"))))))
+
+#+sbcl (require :sb-posix)
+#+(and unix (or sbcl 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#)))))
+
 ;; Various fixings.
 #+clisp (setf custom:*parse-namestring-ansi* t)
 
 ;; Shebang.
 (set-dispatch-macro-character
  #\# #\!
- (lambda (stream char arg)
-   (declare (ignore char arg))
-   (values (read-line stream))))
+ (lambda (#1=#:stream . #2=(#:char #:arg))
+   (declare (ignore . #2#))
+   (values (read-line #1#))))
 
 ;; Start up swank.
 (defun mdw-hacks:crank-swank (&rest #1=#:args)