forked from Shirakumo/trial
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathresource.lisp
54 lines (41 loc) · 1.57 KB
/
resource.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
#|
This file is a part of trial
(c) 2018 Shirakumo http://tymoon.eu (shinmera@tymoon.eu)
Author: Nicolas Hafner <shinmera@tymoon.eu>
|#
(in-package #:org.shirakumo.fraf.trial)
;; FIXME: configurable defaults
(defclass resource ()
((generator :initarg :generator :initform NIL :reader generator)
(name :initarg :name :initform NIL :reader name)))
(defmethod print-object ((resource resource) stream)
(print-unreadable-object (resource stream :type T :identity T)
(format stream "~@[~a~]~@[ ~a~]" (generator resource) (name resource))))
(defgeneric allocate (resource))
(defgeneric deallocate (resource))
(defgeneric allocated-p (resource))
(defmethod load ((resource resource))
(unless (allocated-p resource)
(v:trace :trial.resource "Loading ~a" resource)
(allocate resource)))
(defmethod allocate :around ((resource resource))
(call-next-method)
resource)
(defmethod deallocate :around ((resource resource))
(call-next-method)
resource)
(defun check-allocated (resource)
(unless (allocated-p resource)
(restart-case
(error 'resource-not-allocated :resource resource)
(continue ()
:report "Allocate the resource now and continue."
(allocate resource)))))
(defclass foreign-resource (resource)
((data-pointer :initform NIL :initarg :data-pointer :accessor data-pointer)))
(defmethod allocated-p ((resource foreign-resource))
(data-pointer resource))
(defmethod deallocate :after ((resource foreign-resource))
(setf (data-pointer resource) NIL))
(defclass gl-resource (foreign-resource)
((data-pointer :accessor gl-name)))