((:a :href link) (:princ (string-maybe-shorten name *apache-name-width*))))
(write-name-trailing-spaces stream name))
+(defun universal-time-to-apache-date (utime)
+ (multiple-value-bind
+ (second minute hour day-of-month month year day-of-week daylight-p zone)
+ (decode-universal-time utime)
+ (declare (ignore second day-of-week daylight-p zone))
+ (format nil
+ (formatter "~2,'0D-~3/kmrcl::monthname/-~4,'0D ~2,'0D:~2,'0D")
+ day-of-month month year hour minute)))
+
(defun sort-dir-entries (entries sort-field direct)
(case sort-field
(:name
(let* ((query (when query-string (split-uri-query-string query-string)))
(sort-field (if query
(cond
- ((string-equal (caar query) "N") :name)
- ((string-equal (caar query) "M") :modified)
- ((string-equal (caar query) "S") :size)
- ((string-equal (caar query) "D") :description)
- (t :name))
- :name))
+ ((string-equal (caar query) "N") :name)
+ ((string-equal (caar query) "M") :modified)
+ ((string-equal (caar query) "S") :size)
+ ((string-equal (caar query) "D") :description)
+ (t :name))
+ :name))
(dir (cond
- ((and query (string-equal (cdr (first query)) "D") :desc))
- (t :asc))))
+ ((and query (string-equal (cdr (first query)) "D") :desc))
+ (t :asc))))
(setq entries (sort-dir-entries entries sort-field dir))
-
+
(html-stream
stream
"<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.0 Transitional//EN\" \"http://www.w3.org/TR/REC-html40/loose.dtd\">"
(case (car entry)
(:dir (format nil "~Afolder.png" icon-base))
(:text (format nil "~Atext.png" icon-base))
- (t (format nil "~Af.png" icon-base))]
+ (t (format nil "~Af.png" icon-base)))
:alt
(case (car entry)
(:dir "[DIR]")
(:text "[TXT]")
(t "[FIL]"))))))
- " "
+ " "
(write-name-link stream (second entry) (third entry))
" "
(:princ (universal-time-to-apache-date (fourth entry)))
(in-package #:lml2)
-(defmacro aif (test then &optional else)
- `(let ((it ,test))
- (if it ,then ,else)))
-
-(defmacro awhen (test-form &body body)
- `(aif ,test-form
- (progn ,@body)))
-
-(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)
- (let ((eof (cons 'eof nil)))
- (with-open-file (in file :direction :input)
- (do ((line (read-line in nil eof)
- (read-line in nil eof)))
- ((eq line eof))
- (write-string line strm)
- (write-char #\newline strm))))))
-
-(defun date-string (ut)
- (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."
- #+allegro (excl:exit code)
- #+clisp (#+lisp=cl ext:quit #-lisp=cl lisp: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)))
- #+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)))
-
+ (kmrcl:quit code))
(defun lml-cwd ()
- "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)
- #+(or cmu scl) (ext:default-directory)
- #+cormanlisp (ccl:get-current-directory)
- #+lispworks (hcl:get-working-directory)
- #+lucid (lcl:working-directory)
- #+sbcl (sb-unix:posix-getcwd/)
- #+mcl (ccl:mac-default-directory)
- #-(or allegro clisp cmu scl sbcl cormanlisp lispworks lucid mcl) (truename "."))
-
-
-#+ignore
-(defun fformat (&rest args)
- (declare (dynamic-extent args))
- (apply (if (find-package 'kmrcl)
- (symbol-function (intern (symbol-name #:fformat)
- (symbol-name #:kmrcl)))
- #'format)
- args))
+ "Returns the current working directory."
+ (kmrcl:cwd))
(defmacro fformat (stream control-string &rest args)
(if stream