]> git.jsancho.org Git - gacela.git/blob - gacela/event.scm
04223971108da1a33c1cb4980f41d85aed63b652
[gacela.git] / gacela / event.scm
1 ;;; Gacela, a GNU Guile extension for fast games development
2 ;;; Copyright (C) 2017 by Javier Sancho Fernandez <jsf at jsancho dot org>
3 ;;;
4 ;;; This program is free software: you can redistribute it and/or modify
5 ;;; it under the terms of the GNU General Public License as published by
6 ;;; the Free Software Foundation, either version 3 of the License, or
7 ;;; (at your option) any later version.
8 ;;;
9 ;;; This program is distributed in the hope that it will be useful,
10 ;;; but WITHOUT ANY WARRANTY; without even the implied warranty of
11 ;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12 ;;; GNU General Public License for more details.
13 ;;;
14 ;;; You should have received a copy of the GNU General Public License
15 ;;; along with this program.  If not, see <http://www.gnu.org/licenses/>.
16
17
18 (define-module (gacela event)
19   #:use-module ((sdl2 events) #:prefix sdl2:)
20   #:export (process-events
21             quit-event?
22             key-events
23             any-key-down?
24             any-key-up?
25             key-down?
26             key-up?))
27
28
29 (define *current-events* '())
30
31 (define (poll-events)
32   (let ((event (sdl2:poll-event)))
33     (cond (event
34            (cons event (poll-events)))
35           (else
36            '()))))
37
38 (define (process-events)
39   (set! *current-events* (poll-events)))
40
41 (define (quit-event?)
42   (not (null? (filter (lambda (e) (sdl2:quit-event? e)) *current-events*))))
43
44 (define (key-events)
45   (filter (lambda (e) (sdl2:keyboard-event? e)) *current-events*))
46
47 (define (any-key-down?)
48   (let loop ((events *current-events*))
49     (if (null? events)
50         #f
51         (or (sdl2:keyboard-down-event? (car events))
52             (loop (cdr events))))))
53
54 (define (any-key-up?)
55   (let loop ((events *current-events*))
56     (if (null? events)
57         #f
58         (or (sdl2:keyboard-up-event? (car events))
59             (loop (cdr events))))))
60
61 (define (key-down? key)
62   (let ((ke (filter
63              (lambda (e)
64                (and (sdl2:keyboard-down-event? e)
65                     (equal? (sdl2:keyboard-event-key e) key)))
66              *current-events*)))
67     (not (null? ke))))
68
69 (define (key-up? key)
70   (let ((ke (filter
71              (lambda (e)
72                (and (sdl2:keyboard-up-event? e)
73                     (equal? (sdl2:keyboard-event-key e) key)))
74              *current-events*)))
75     (not (null? ke))))