X-Git-Url: https://git.jsancho.org/?a=blobdiff_plain;f=irrlicht%2Fdevice.scm;h=0fdeed7ffecad1484d7e473a6e497a87ed654f7e;hb=3bb58c2b45af12c0f9c9eac648e67ac6fa90e104;hp=928a6c8e51cf362b2506c430cf2825b623f8479c;hpb=d8367430b147ccdb2505295a7d50f1f412b4e6e1;p=guile-irrlicht.git diff --git a/irrlicht/device.scm b/irrlicht/device.scm index 928a6c8..0fdeed7 100644 --- a/irrlicht/device.scm +++ b/irrlicht/device.scm @@ -1,5 +1,5 @@ ;;; guile-irrlicht --- FFI bindings for Irrlicht Engine -;;; Copyright (C) 2019 Javier Sancho +;;; Copyright (C) 2020 Javier Sancho ;;; ;;; This file is part of guile-irrlicht. ;;; @@ -19,22 +19,19 @@ (define-module (irrlicht device) - #:use-module (ice-9 match) - #:use-module (system foreign) - #:use-module ((irrlicht bindings) #:prefix ffi:) - #:use-module ((irrlicht bindings core) #:prefix ffi-core:) - #:use-module ((irrlicht bindings video) #:prefix ffi-video:) - #:use-module (irrlicht util) - #:export (create-device - get-cursor-control - get-file-system - get-video-driver - get-gui-environment - get-scene-manager - is-window-active? - set-window-caption! - device-run? - device-drop!)) + #:use-module (oop goops) + #:use-module (irrlicht base) + #:use-module (irrlicht foreign) + #:use-module ((irrlicht irr) #:select ( ))) + + +;; IrrlichtDevice +(define-class () + (irr-class #:init-value "IrrlichtDevice")) + +(define-method (close-device (device )) + (let ((closeDevice (get-irrlicht-proc "closeDevice" device))) + (closeDevice device))) (define* (create-device #:key (device-type 'software) @@ -42,45 +39,70 @@ (bits 16) (fullscreen #f) (stencilbuffer #f) - (vsync #f)) - (let ((driver (match device-type - ('null ffi-video:EDT_NULL) - ('software ffi-video:EDT_SOFTWARE) - ('burnings ffi-video:EDT_BURNINGSVIDEO) - ('direct3d8 ffi-video:EDT_DIRECT3D8) - ('direct3d9 ffi-video:EDT_DIRECT3D9) - ('opengl ffi-video:EDT_OPENGL) - ('count ffi-video:EDT_COUNT))) - (wsize (make-c-struct ffi-core:dimension2d window-size))) - (let ((device (ffi:create-device driver wsize bits - (bool->integer fullscreen) - (bool->integer stencilbuffer) - (bool->integer vsync)))) - (if (null-pointer? device) #f device)))) - -(define (get-cursor-control device) - (ffi:get-cursor-control device)) - -(define (get-file-system device) - (ffi:get-file-system device)) - -(define (get-video-driver device) - (ffi:get-video-driver device)) - -(define (get-gui-environment device) - (ffi:get-gui-environment device)) - -(define (get-scene-manager device) - (ffi:get-scene-manager device)) - -(define (is-window-active? device) - (integer->bool (ffi:is-window-active device))) - -(define (set-window-caption! device text) - (ffi:set-window-caption device (string->pointer text))) - -(define (device-run? device) - (integer->bool (ffi:run device))) - -(define (device-drop! device) - (integer->bool (ffi:drop device))) + (vsync #f) + (receiver (make ))) + (if (not (is-a? receiver )) + (error + "In procedure create-device: Wrong type argument (expecting ):" + receiver)) + + (let* ((createDevice (get-irrlicht-proc "createDevice")) + (device (createDevice device-type window-size bits fullscreen stencilbuffer + vsync receiver))) + (if (null-object? device) + (error "In procedure create-device: Device cannot be created") + device))) + +(define-method (get-cursor-control (device )) + (let ((getCursorControl (get-irrlicht-proc "getCursorControl" device))) + (getCursorControl device))) + +(define-method (get-file-system (device )) + (let ((getFileSystem (get-irrlicht-proc "getFileSystem" device))) + (getFileSystem device))) + +(define-method (get-gui-environment (device )) + (let ((getGUIEnvironment (get-irrlicht-proc "getGUIEnvironment" device))) + (getGUIEnvironment device))) + +(define-method (get-scene-manager (device )) + (let ((getSceneManager (get-irrlicht-proc "getSceneManager" device))) + (getSceneManager device))) + +(define-method (get-timer (device )) + (let ((getTimer (get-irrlicht-proc "getTimer" device))) + (getTimer device))) + +(define-method (get-video-driver (device )) + (let* ((getVideoDriver (get-irrlicht-proc "getVideoDriver" device)) + (driver (getVideoDriver device))) + (if (null-object? driver) + (error "In procedure get-video-driver: Driver unavailable") + driver))) + +(define-method (is-window-active? (device )) + (let ((isWindowActive (get-irrlicht-proc "isWindowActive" device))) + (isWindowActive device))) + +(define-method (run (device )) + ((get-irrlicht-proc "run" device) device)) + +(define-method (set-event-receiver! (device ) (receiver )) + (let ((setEventReceiver (get-irrlicht-proc "setEventReceiver" device receiver))) + (setEventReceiver device receiver))) + +(define-method (set-resizable! (device ) resize) + (let ((setResizable (get-irrlicht-proc "setResizable" device))) + (setResizable device resize))) + +(define-method (set-window-caption! (device ) text) + ((get-irrlicht-proc "setWindowCaption" device) + device text)) + +(define-method (yield-device (device )) + (let ((yield (get-irrlicht-proc "yield" device))) + (yield device))) + +(export close-device create-device get-cursor-control get-file-system + get-gui-environment get-scene-manager get-timer get-video-driver is-window-active? run + set-event-receiver! set-resizable! set-window-caption! yield-device)