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
;;
;; LowH Triangle Assets - Asset pipeline
;;
;; Copyright 2012 Thomas de Grivel <billitch@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 :RoL-assets)
;; Asset generators
(defvar *generator* nil)
(defun generator (name)
(declare (type symbol name))
(setf *generator* name))
(defun generate/file (path)
(let (*generator*
(dir (enough-namestring
(truename
(merge-pathnames "../" (make-pathname :name nil :type nil
:defaults path))))))
(when (zerop (length dir))
(setq dir "./"))
(msg "~A" dir)
(with-msg-indent (1)
(load path)
(funcall *generator* dir))))
(defun generate ()
(msg "Generate")
(with-msg-indent (1)
(mapc #'generate/file (directory "triangle/assets.lisp"))
(mapc #'generate/file (directory "*/triangle/assets.lisp"))
(mapc #'generate/file (directory "lib/triangle/*/triangle/assets.lisp"))
(mapc #'generate/file (directory "lib/*/triangle/assets.lisp"))))