X-Git-Url: https://git.jsancho.org/?a=blobdiff_plain;f=irrlicht%2Fdevice.scm;h=6e9dfcc8cf0c0a1a7d0f05d7855873710ba5b604;hb=09e9ed196aadab0f77e831c134fce8bdb58b772b;hp=c773dbc99d96af6fc5fc027c06dbe32788057228;hpb=71e6e638cba09643fca5dccd1b7295b7db0def06;p=guile-irrlicht.git diff --git a/irrlicht/device.scm b/irrlicht/device.scm index c773dbc..6e9dfcc 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,69 +19,68 @@ (define-module (irrlicht device) - #:use-module (ice-9 match) - #:use-module (system foreign) - #:use-module ((irrlicht bindings) #:prefix ffi:) - #:use-module ((irrlicht bindings video) #:prefix ffi-video:) - #:use-module (irrlicht dimension2d) - #: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 io) + #:use-module (irrlicht irr) + #:use-module (irrlicht gui) + #:use-module (irrlicht scene) + #:use-module (irrlicht video)) + + +;; IrrlichtDevice +(define-class () + (irr-class #:init-value "IrrlichtDevice" #:getter irr-class)) (define* (create-device #:key (device-type 'software) - (window-size (make-dimension2d 640 480)) + (window-size '(640 480)) (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)))) - (let ((device (ffi:create-device driver - (foreign-record->pointer window-size) - 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)) + (vsync #f) + (receiver (make ))) + (if (not (is-a? receiver )) + (error + "In procedure create-device: Wrong type argument (expecting ):" + receiver)) -(define (get-file-system device) - (ffi:get-file-system device)) + (make + #:irr-pointer + ((get-irrlicht-proc "createDevice") + device-type + window-size + bits + fullscreen + stencilbuffer + vsync + receiver))) -(define (get-video-driver device) - (ffi:get-video-driver device)) +(define-method (get-file-system (device )) + (let ((getFileSystem (get-irrlicht-proc "getFileSystem" device))) + (make + #:irr-pointer (getFileSystem device)))) -(define (get-gui-environment device) - (ffi:get-gui-environment device)) +(define-method (get-gui-environment (device )) + (let ((getGUIEnvironment (get-irrlicht-proc "getGUIEnvironment" device))) + (make + #:irr-pointer (getGUIEnvironment device)))) -(define (get-scene-manager device) - (ffi:get-scene-manager device)) +(define-method (get-scene-manager (device )) + (make + #:irr-pointer ((get-irrlicht-proc "getSceneManager" device) device))) -(define (is-window-active? device) - (integer->bool (ffi:is-window-active device))) +(define-method (get-video-driver (device )) + (make + #:irr-pointer ((get-irrlicht-proc "getVideoDriver" device) device))) -(define (set-window-caption! device text) - (ffi:set-window-caption device (string->pointer text))) +(define-method (run (device )) + ((get-irrlicht-proc "run" device) device)) -(define (device-run? device) - (integer->bool (ffi:run device))) +(define-method (set-window-caption! (device ) text) + ((get-irrlicht-proc "setWindowCaption" device) + device text)) -(define (device-drop! device) - (integer->bool (ffi:drop device))) +(export create-device get-file-system get-gui-environment get-scene-manager get-video-driver run + set-window-caption!)