/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*))
 |