Hash :
50a37142
Author :
Thomas de Grivel
Date :
2020-04-13T03:07:17
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
;;
;; adams - system administrator written in Common Lisp
;;
;; Copyright 2020 Thomas de Grivel <thoxdg@gmail.com>
;;
;; Permission to use, copy, modify, and distribute this software for any
;; purpose with or without fee is hereby granted, provided that the above
;; copyright notice and this permission notice appear in all copies.
;;
;; THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
;; WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
;; MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
;; ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
;; WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
;; ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
;; OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
;;
(in-package :adams)
(defun include/resolve-filename (spec)
(flet ((try (&rest parts)
(let ((path (str parts)))
(when (probe-file path)
(return-from include/resolve-filename path)))))
(try spec)
(try spec ".adams")))
(defun include/resolve-filename! (spec)
(or (include/resolve-filename spec)
(error "(include ~S) => file not found.~%
Current directory : ~S" source *default-pathname-defaults*)))
(defun include (&rest sources)
(let* ((head (cons 'list nil))
(tail head)
(eof (gensym "EOF")))
(dolist (source sources)
(let ((path (include/resolve-filename! source)))
(with-open-file (in path
:element-type 'character
:external-format :utf-8)
(loop
(let ((form (read in nil eof)))
(when (eq form eof)
(return))
(setf (rest tail) (cons form nil)
tail (rest tail)))))))
head))