r11296: add optional final rightcol files
[lml2.git] / files.lisp
index a3dbf6ee34fee826e1df9c29d77bdf1ac6907f09..9c5dd2ed95906fb91ceb6749a3d62df9e59fc997 100644 (file)
@@ -27,7 +27,8 @@
   (when (stringp f)
     (unless (position #\. f)
       (setq f (concatenate 'string f ".html"))))
-  (if *sources-dir*
+  (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)
          (*sources-dir* ,sources-dir))
       ,@body))))
 
-(defun lml-load-path (file)
+(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)))
-    (format *trace-output* "Warning: unable to load LML file ~S" file)))
+    (unless optional
+      (format *trace-output* "Warning: unable to load LML file ~S" file))))
 
 (defun process-dir (dir &key sources)
   (with-dir (dir :sources sources)
@@ -72,8 +74,8 @@
        (format *trace-output* "~&; Processing ~A~%" file)
        (lml-load-path file)))))
 
-(defun lml-load (file)
-  (lml-load-path (eval `(lml-file-name ,file :source))))
+(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*))