-
Notifications
You must be signed in to change notification settings - Fork 19
/
Copy pathwl-surface-impl.lisp
55 lines (45 loc) · 2.25 KB
/
wl-surface-impl.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
(in-package :ulubis)
(defimplementation wl-callback ()
()
())
(def-wl-callback commit (client surface)
(setf (committed surface) t)
(create-texture surface)
(when (and (buffer surface) (first-commit? surface))
(let ((current-view (active-surface (screen *compositor*))))
(first-commit (current-mode current-view) (role surface))))
(setf (render-needed *compositor*) t))
(def-wl-callback attach (client surface (buffer :pointer) (x :int32) (y :int32))
(setf (buffer surface) buffer))
(def-wl-callback frame (client surface (callbackid :uint32))
(let ((frame-callback (make-wl-callback client 1 callbackid :implementation? nil)))
(setf (frame-callback surface) frame-callback)
(push frame-callback (callbacks *compositor*))))
(def-wl-callback set-input-region (client surface (region :pointer))
(setf (input-region surface) (find-resource client region)))
(def-wl-callback set-opaque-region (client surface (region :pointer))
(setf (opaque-region surface) (find-resource client region)))
(def-wl-callback surface-destroy (client surface)
(setf (role surface) nil)
(setf (wl-surface surface) nil)
(setf (callbacks *compositor*) (remove (frame-callback surface) (callbacks *compositor*)))
(setf (frame-callback surface) nil))
(defimplementation wl-surface (isurface ianimatable)
((:commit commit)
(:attach attach)
(:frame frame)
(:set-input-region set-input-region)
(:set-opaque-region set-opaque-region)
(:destroy surface-destroy))
((frame-callback :accessor frame-callback :initarg :frame-callback :initform nil)
(committed :accessor committed :initarg :committed :initform nil)
(input-region :accessor input-region :initarg :input-region :initform nil)
(opaque-region :accessor opaque-region :initarg :opaque-region :initform nil)
(texture :accessor texture :initarg :texture :initform nil)
(role :accessor role :initarg :role :initform nil)
(buffer :accessor buffer :initarg :buffer :initform nil)
(first-commit? :accessor first-commit? :initarg :first-commit? :initform t)))
;; Override print object
(defmethod print-object ((obj wl-surface) out)
(print-unreadable-object (obj out :type t)
(format out "~s@~X [~Ax~A]" (id obj) (cffi:pointer-address (->resource obj)) (width obj) (height obj))))