X-Git-Url: https://git.jsancho.org/?a=blobdiff_plain;f=irrlicht%2Fdevice.scm;h=c922cece2076b139f62b51f36fd0e51cb2129a2b;hb=e310847d00a2fd941405b0d417542310dad63965;hp=b18a58e690c49870a4b340f33b86ee6b76008757;hpb=0c07b0db5cf3aec92ae8838490d6a83e5416d81c;p=guile-irrlicht.git diff --git a/irrlicht/device.scm b/irrlicht/device.scm index b18a58e..c922cec 100644 --- a/irrlicht/device.scm +++ b/irrlicht/device.scm @@ -46,39 +46,33 @@ "In procedure create-device: Wrong type argument (expecting ):" receiver)) - (make - #:irr-pointer - ((get-irrlicht-proc "createDevice") - device-type - window-size - bits - fullscreen - stencilbuffer - vsync - receiver))) + (let* ((createDevice (get-irrlicht-proc "createDevice")) + (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 + 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-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))) @@ -95,5 +89,5 @@ (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-video-driver is-window-active? run set-window-caption! yield-device)