Update domain name to kpe.io
[lml.git] / utils.lisp
index 37fb99d642b430acd88fac08e14d0337c7825330..9c2f9799ec661f199606af985fe5adebaf72715d 100644 (file)
@@ -1,9 +1,8 @@
-;;; $Id: utils.lisp,v 1.2 2002/10/14 03:28:22 kevin Exp $
+;;; $Id$
 ;;;;
 ;;;; General purpose utilities
 
-(in-package :lml)
-
+(in-package #:lml)
 
 (defmacro aif (test then &optional else)
   `(let ((it ,test))
        (string-equal "keyword" (package-name (symbol-package x)))))
 
 (defun list-to-spaced-string (list)
-  (format nil "~{ ~A~}" list))
+  (format nil "~{~A~^ ~}" list))
+
+(defun print-n-chars (char n stream)
+  (declare (fixnum n)
+           (optimize (speed 3) (safety 0) (space 0)))
+  (do ((i 0 (1+ i)))
+      ((= i n) char)
+    (declare (fixnum i))
+    (write-char char stream)))
 
 (defun indent-spaces (n &optional (stream *standard-output*))
   "Indent n*2 spaces to output stream"
-  (let ((fmt (format nil "~~~DT" (+ n n))))
-    (format stream fmt)))
+  (print-n-chars #\space (+ n n) stream))
 
 (defun print-file-contents (file &optional (strm *standard-output*))
   "Opens a reads a file. Returns the contents as a single string"
   (when (probe-file file)
     (with-open-file (in file :direction :input)
-                   (do ((line (read-line in nil 'eof) 
-                              (read-line in nil 'eof)))
-                       ((eql line 'eof))
-                     (format strm "~A~%" line)))))
+                    (do ((line (read-line in nil 'eof)
+                               (read-line in nil 'eof)))
+                        ((eql line 'eof))
+                      (write-string line strm)
+                      (write-char #\newline strm)))))
 
 (defun date-string (ut)
-  (if (typep ut 'integer)
-      (multiple-value-bind (sec min hr day mon year dow daylight-p zone)
-         (decode-universal-time ut)
-       (declare (ignore daylight-p zone))
-       (format nil "~[Mon~;Tue~;Wed~;Thu~;Fri~;Sat~;Sun~], ~d ~[Jan~;Feb~;Mar~;Apr~;May~;Jun~;Jul~;Aug~;Sep~;Oct~;Nov~;Dec~] ~d ~2,'0d:~2,'0d:~2,'0d" 
-               dow
-               day
-               (1- mon)
-               year
-               hr min sec))))
+  (check-type ut integer)
+  (multiple-value-bind (sec min hr day mon year dow daylight-p zone)
+      (decode-universal-time ut)
+    (declare (ignore daylight-p zone))
+    (format nil "~[Mon~;Tue~;Wed~;Thu~;Fri~;Sat~;Sun~], ~d ~[Jan~;Feb~;Mar~;Apr~;May~;Jun~;Jul~;Aug~;Sep~;Oct~;Nov~;Dec~] ~d ~2,'0d:~2,'0d:~2,'0d"
+            dow day (1- mon) year hr min sec)))
 
 (defun lml-quit (&optional (code 0))
-  "Function to exit the Lisp implementation. Copied from CLOCC's QUIT function."
+  "Function to exit the Lisp implementation."
     #+allegro (excl:exit code)
     #+clisp (#+lisp=cl ext:quit #-lisp=cl lisp:quit code)
-    #+cmu (ext:quit code)
+    #+(or cmu scl) (ext:quit code)
     #+cormanlisp (win32:exitprocess code)
     #+gcl (lisp:bye code)
     #+lispworks (lw:quit :status code)
     #+lucid (lcl:quit code)
     #+sbcl (sb-ext:quit :unix-status (typecase code (number code) (null 0) (t 1)))
-    #-(or allegro clisp cmu cormanlisp gcl lispworks lucid sbcl)
+    #+openmcl (ccl:quit code)
+    #+(and mcl (not openmcl)) (declare (ignore code))
+    #+(and mcl (not openmcl)) (ccl:quit)
+    #-(or allegro clisp cmu scl cormanlisp gcl lispworks lucid sbcl mcl)
     (error 'not-implemented :proc (list 'quit code)))
 
 
   "Returns the current working directory. Based on CLOCC's DEFAULT-DIRECTORY function."
   #+allegro (excl:current-directory)
   #+clisp (#+lisp=cl ext:default-directory #-lisp=cl lisp:default-directory)
-  #+cmu (ext:default-directory)
+  #+(or cmu scl) (ext:default-directory)
   #+cormanlisp (ccl:get-current-directory)
   #+lispworks (hcl:get-working-directory)
   #+lucid (lcl:working-directory)
-  #-(or allegro clisp cmu cormanlisp lispworks lucid) (truename "."))
+  #+sbcl (sb-unix:posix-getcwd/)
+  #+mcl (ccl:mac-default-directory)
+  #-(or allegro clisp cmu scl sbcl cormanlisp lispworks lucid mcl) (truename "."))
+
 
-