]> git.jsancho.org Git - gacela.git/blob - gacela/event.scm
Store all events when lag is produced
[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             clear-events
22             quit-event?
23             key-events
24             any-key-down?
25             any-key-up?
26             key-down?
27             key-up?))
28
29
30 (define *current-events* '())
31
32 (define (poll-events)
33   (let ((event (sdl2:poll-event)))
34     (cond (event
35            (cons event (poll-events)))
36           (else
37            '()))))
38
39 (define (clear-events)
40   (set! *current-events* '()))
41
42 (define (process-events)
43   (set! *current-events* (append *current-events* (poll-events))))
44
45 (define (quit-event?)
46   (not (null? (filter (lambda (e) (sdl2:quit-event? e)) *current-events*))))
47
48 (define (key-events)
49   (filter (lambda (e) (sdl2:keyboard-event? e)) *current-events*))
50
51 (define (any-key-down?)
52   (let loop ((events *current-events*))
53     (if (null? events)
54         #f
55         (or (sdl2:keyboard-down-event? (car events))
56             (loop (cdr events))))))
57
58 (define (any-key-up?)
59   (let loop ((events *current-events*))
60     (if (null? events)
61         #f
62         (or (sdl2:keyboard-up-event? (car events))
63             (loop (cdr events))))))
64
65 (define (key-down? key)
66   (let ((ke (filter
67              (lambda (e)
68                (and (sdl2:keyboard-down-event? e)
69                     (equal? (sdl2:keyboard-event-key e) key)))
70              *current-events*)))
71     (not (null? ke))))
72
73 (define (key-up? key)
74   (let ((ke (filter
75              (lambda (e)
76                (and (sdl2:keyboard-up-event? e)
77                     (equal? (sdl2:keyboard-event-key e) key)))
78              *current-events*)))
79     (not (null? ke))))