X-Git-Url: https://git.jsancho.org/?a=blobdiff_plain;f=irrlicht%2Fdevice.scm;h=e5eac5a5b460c616d51ebc4b58fd02374ad58ba1;hb=7ef67d269cc1f6d9f9c58583c100d761d77801d8;hp=04988d39602e24deb51ead3f2cce967fccbaa750;hpb=384a8fb56d8500dc3551085191a39c9da70e221c;p=guile-irrlicht.git diff --git a/irrlicht/device.scm b/irrlicht/device.scm index 04988d3..e5eac5a 100644 --- a/irrlicht/device.scm +++ b/irrlicht/device.scm @@ -22,11 +22,7 @@ #: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)) + #:use-module ((irrlicht irr) #:select ( ))) ;; IrrlichtDevice @@ -47,35 +43,36 @@ receiver)) (let* ((createDevice (get-irrlicht-proc "createDevice")) - (device-pointer (createDevice device-type window-size bits fullscreen stencilbuffer - vsync receiver))) - (cond ((null-pointer? device-pointer) + (device (createDevice device-type window-size bits fullscreen stencilbuffer + vsync receiver))) + (cond ((null-object? device) (error "In procedure create-device: Device cannot be created")) (else - (make #:irr-pointer device-pointer))))) + device)))) (define-method (get-cursor-control (device )) (let ((getCursorControl (get-irrlicht-proc "getCursorControl" device))) - (make - #:irr-pointer (getCursorControl device)))) + (getCursorControl device))) (define-method (get-file-system (device )) (let ((getFileSystem (get-irrlicht-proc "getFileSystem" device))) - (make - #:irr-pointer (getFileSystem device)))) + (getFileSystem device))) (define-method (get-gui-environment (device )) (let ((getGUIEnvironment (get-irrlicht-proc "getGUIEnvironment" device))) - (make - #:irr-pointer (getGUIEnvironment device)))) + (getGUIEnvironment device))) (define-method (get-scene-manager (device )) - (make - #:irr-pointer ((get-irrlicht-proc "getSceneManager" device) 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 )) - (make - #:irr-pointer ((get-irrlicht-proc "getVideoDriver" device) device))) + (let ((getVideoDriver (get-irrlicht-proc "getVideoDriver" device))) + (getVideoDriver device))) (define-method (is-window-active? (device )) (let ((isWindowActive (get-irrlicht-proc "isWindowActive" device))) @@ -84,6 +81,14 @@ (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)) @@ -92,5 +97,6 @@ (let ((yield (get-irrlicht-proc "yield" device))) (yield device))) -(export create-device get-cursor-control get-file-system get-gui-environment get-scene-manager - get-video-driver is-window-active? run set-window-caption! yield-device) +(export 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)