/usr/share/common-lisp/source/lml2/files.lisp is in cl-lml2 1.6.6-4.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 | ;;;; -*- Mode: LISP; Syntax: ANSI-Common-Lisp; Base: 10 -*-
;;;; *************************************************************************
;;;; FILE IDENTIFICATION
;;;;
;;;; Name: files.lisp
;;;; Purpose: File and directory functions for LML
;;;; Programmer: Kevin M. Rosenberg
;;;; Date Started: Aug 2002
;;;;
;;;; This file, part of LML2, is Copyright (c) 2000-2003 by Kevin Rosenberg.
;;;; Rights of modification and redistribution are in the LICENSE file.
;;;;
;;;; *************************************************************************
(in-package #:lml2)
(eval-when (:compile-toplevel :load-toplevel :execute)
(defvar *output-dir* nil)
(defvar *sources-dir* nil)
)
(defun lml-file-name (f &optional (type :source))
(when (and (consp f) (eql (car f) 'cl:quote))
(setq f (cadr f)))
(when (symbolp f)
(setq f (string-downcase (symbol-name f))))
(when (stringp f)
(unless (position #\. f)
(setq f (concatenate 'string f ".html"))))
(if (or (and (eq type :source) *sources-dir*)
(and (eq type :output) *output-dir*))
(merge-pathnames
(make-pathname :name (pathname-name f)
:type (pathname-type f)
:directory (pathname-directory f))
(ecase type
(:source *sources-dir*)
(:output *output-dir*)))
(if (stringp f)
(parse-namestring f)
f)))
(defmacro with-dir ((output &key sources) &body body)
(let ((output-dir (gensym))
(sources-dir (gensym)))
`(let ((,output-dir ,output)
(,sources-dir ,sources))
(when (stringp ,output-dir)
(setq ,output-dir (parse-namestring ,output-dir)))
(when (stringp ,sources-dir)
(setq ,sources-dir (parse-namestring ,sources-dir)))
(unless ,sources-dir
(setq ,sources-dir ,output-dir))
(let ((*output-dir* ,output-dir)
(*sources-dir* ,sources-dir))
,@body))))
(defun lml-load-path (file &key optional)
(if (probe-file file)
(with-open-file (in file :direction :input)
(do ((form (read in nil 'eof) (read in nil 'eof)))
((eq form 'eof))
(eval form)))
(unless optional
(format *trace-output* "Warning: unable to load LML file ~S" file))))
(defun process-dir (dir &key sources)
(with-dir (dir :sources sources)
(let ((lml-files (directory
(make-pathname :defaults *sources-dir*
:name :wild
:type "lml"))))
(dolist (file lml-files)
(format *trace-output* "~&; Processing ~A~%" file)
(lml-load-path file)))))
(defun lml-load (file &key optional)
(lml-load-path (eval `(lml-file-name ,file :source)) :optional optional))
(defun insert-file (file)
(print-file-contents file *html-stream*))
|