]> git.jsancho.org Git - guile-irrlicht.git/blob - irrlicht/device.scm
051cddddada3942b0ec3072172f9d38d6900035b
[guile-irrlicht.git] / irrlicht / device.scm
1 ;;; guile-irrlicht --- FFI bindings for Irrlicht Engine
2 ;;; Copyright (C) 2019 Javier Sancho <jsf@jsancho.org>
3 ;;;
4 ;;; This file is part of guile-irrlicht.
5 ;;;
6 ;;; Guile-irrlicht is free software; you can redistribute it and/or modify
7 ;;; it under the terms of the GNU Lesser General Public License as
8 ;;; published by the Free Software Foundation; either version 3 of the
9 ;;; License, or (at your option) any later version.
10 ;;;
11 ;;; Guile-irrlicht is distributed in the hope that it will be useful, but
12 ;;; WITHOUT ANY WARRANTY; without even the implied warranty of
13 ;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14 ;;; General Public License for more details.
15 ;;;
16 ;;; You should have received a copy of the GNU Lesser General Public
17 ;;; License along with guile-irrlicht.  If not, see
18 ;;; <http://www.gnu.org/licenses/>.
19
20
21 (define-module (irrlicht device)
22   #:use-module (ice-9 match)
23   #:use-module (system foreign)
24   #:use-module ((irrlicht bindings) #:prefix ffi:)
25   #:use-module ((irrlicht bindings video) #:prefix ffi-video:)
26   #:use-module (irrlicht dimension2d)
27   #:use-module (irrlicht util)
28   #:export (create-device
29             get-cursor-control
30             get-file-system
31             get-video-driver
32             get-gui-environment
33             get-scene-manager
34             is-window-active?
35             set-window-caption!
36             device-run?
37             device-drop!))
38
39 (define* (create-device #:key
40                         (device-type 'software)
41                         (window-size (make-dimension2d 640 480))
42                         (bits 16)
43                         (fullscreen #f)
44                         (stencilbuffer #f)
45                         (vsync #f))
46   (let ((driver (match device-type
47                        ('null ffi-video:EDT_NULL)
48                        ('software ffi-video:EDT_SOFTWARE)
49                        ('burnings ffi-video:EDT_BURNINGSVIDEO)
50                        ('direct3d8 ffi-video:EDT_DIRECT3D8)
51                        ('direct3d9 ffi-video:EDT_DIRECT3D9)
52                        ('opengl ffi-video:EDT_OPENGL)
53                        ('count ffi-video:EDT_COUNT))))
54     (let ((device (ffi:create-device driver
55                                      (dimension2d->pointer window-size)
56                                      bits
57                                      (bool->integer fullscreen)
58                                      (bool->integer stencilbuffer)
59                                      (bool->integer vsync))))
60       (if (null-pointer? device) #f device))))
61
62 (define (get-cursor-control device)
63   (ffi:get-cursor-control device))
64
65 (define (get-file-system device)
66   (ffi:get-file-system device))
67
68 (define (get-video-driver device)
69   (ffi:get-video-driver device))
70
71 (define (get-gui-environment device)
72   (ffi:get-gui-environment device))
73
74 (define (get-scene-manager device)
75   (ffi:get-scene-manager device))
76
77 (define (is-window-active? device)
78   (integer->bool (ffi:is-window-active device)))
79
80 (define (set-window-caption! device text)
81   (ffi:set-window-caption device (string->pointer text)))
82
83 (define (device-run? device)
84   (integer->bool (ffi:run device)))
85
86 (define (device-drop! device)
87   (integer->bool (ffi:drop device)))