-
-
Notifications
You must be signed in to change notification settings - Fork 49
/
resource-generator.lisp
58 lines (42 loc) · 2.55 KB
/
resource-generator.lisp
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
(in-package #:org.shirakumo.fraf.trial)
(defclass resource-generator ()
())
(defgeneric generate-resources (generator input &key &allow-other-keys))
(defgeneric resource (generator identifier))
(defmethod resource ((generator resource-generator) id) NIL)
(defmethod generate-resources ((generator symbol) input &rest args)
(apply #'generate-resources (make-instance generator) input args))
(defclass compiled-generator (resource-generator)
())
(defgeneric compile-resources (generator source &key))
(defmethod generate-resources :before ((generator compiled-generator) source &key compile)
(when compile
(compile-resources generator source)))
(defun recompile-needed-p (targets sources)
(let ((latest (loop for source in (enlist sources)
maximize (file-write-date source))))
(loop for target in (enlist targets)
thereis (or (null (probe-file target))
(< (file-write-date target) latest)))))
(defgeneric transcode (source source-type target target-type &key))
(defun normalize-file-type (type)
(etypecase type
(pathname (normalize-file-type (pathname-type type)))
(string (or (cl-ppcre:register-groups-bind (type) ("^[^/]*/([^+/]+)" type) (kw type)) (kw type)))
(keyword type)))
(defmethod transcode (source (source-type (eql T)) target target-type &rest args &key &allow-other-keys)
(apply #'transcode source (pathname-type source) target target-type args))
(defmethod transcode (source source-type target (target-type (eql T)) &rest args &key &allow-other-keys)
(apply #'transcode source source-type target (pathname-type target) args))
(defmethod transcode (source (source-type string) target target-type &rest args &key &allow-other-keys)
(apply #'transcode source (normalize-file-type source-type) target target-type args))
(defmethod transcode (source source-type target (target-type string) &rest args &key &allow-other-keys)
(apply #'transcode source source-type target (normalize-file-type target-type) args))
(defmethod transcode :before (source (source-type symbol) target (target-type symbol) &key &allow-other-keys)
(v:info :trial.resource "Transcoding ~a to ~a" source target-type))
(defmethod transcode (source (source-type symbol) target (target-type symbol) &key &allow-other-keys)
(if (next-method-p)
(call-next-method)
(let ((types (list-eql-specializers #'transcode 1 3)))
(error "Don't know how to transcode from ~a to ~a~%known transcoder types are:~%~{ ~a~%~}Did you load the respective format system?"
source-type target-type types))))