#:use-module (oop goops)
#:use-module (irrlicht base)
#:use-module (irrlicht foreign)
- #:use-module (irrlicht irr)
- #:use-module (irrlicht gui)
- #:use-module (irrlicht scene)
- #:use-module (irrlicht video))
+ #:use-module ((irrlicht irr) #:select (<event-receiver> <reference-counted>)))
;; IrrlichtDevice
-(define-class <irrlicht-device> (<reference-counted>))
+(define-class <irrlicht-device> (<reference-counted>)
+ (irr-class #:init-value "IrrlichtDevice"))
+
+(define-method (close-device (device <irrlicht-device>))
+ (let ((closeDevice (get-irrlicht-proc "closeDevice" device)))
+ (closeDevice device)))
(define* (create-device #:key
(device-type 'software)
"In procedure create-device: Wrong type argument (expecting <event-receiver>):"
receiver))
- (make <irrlicht-device>
- #:irr-pointer
- (irr_createDevice
- device-type
- window-size
- bits
- fullscreen
- stencilbuffer
- vsync
- (irr-pointer 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 <irrlicht-device>))
+ (let ((getCursorControl (get-irrlicht-proc "getCursorControl" device)))
+ (getCursorControl device)))
+
+(define-method (get-file-system (device <irrlicht-device>))
+ (let ((getFileSystem (get-irrlicht-proc "getFileSystem" device)))
+ (getFileSystem device)))
(define-method (get-gui-environment (device <irrlicht-device>))
- (make <gui-environment>
- #:irr-pointer (irr_IrrlichtDevice_getGUIEnvironment (irr-pointer device))))
+ (let ((getGUIEnvironment (get-irrlicht-proc "getGUIEnvironment" device)))
+ (getGUIEnvironment device)))
(define-method (get-scene-manager (device <irrlicht-device>))
- (make <scene-manager>
- #:irr-pointer (irr_IrrlichtDevice_getSceneManager (irr-pointer device))))
+ (let ((getSceneManager (get-irrlicht-proc "getSceneManager" device)))
+ (getSceneManager device)))
+
+(define-method (get-timer (device <irrlicht-device>))
+ (let ((getTimer (get-irrlicht-proc "getTimer" device)))
+ (getTimer device)))
(define-method (get-video-driver (device <irrlicht-device>))
- (make <video-driver>
- #:irr-pointer (irr_IrrlichtDevice_getVideoDriver (irr-pointer 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 <irrlicht-device>))
+ (let ((isWindowActive (get-irrlicht-proc "isWindowActive" device)))
+ (isWindowActive device)))
+
+(define-method (run (device <irrlicht-device>))
+ ((get-irrlicht-proc "run" device) device))
+
+(define-method (set-event-receiver! (device <irrlicht-device>) (receiver <event-receiver>))
+ (let ((setEventReceiver (get-irrlicht-proc "setEventReceiver" device receiver)))
+ (setEventReceiver device receiver)))
+
+(define-method (set-resizable! (device <irrlicht-device>) resize)
+ (let ((setResizable (get-irrlicht-proc "setResizable" device)))
+ (setResizable device resize)))
(define-method (set-window-caption! (device <irrlicht-device>) text)
- (irr_IrrlichtDevice_setWindowCaption (irr-pointer device) text))
+ ((get-irrlicht-proc "setWindowCaption" device)
+ device text))
+
+(define-method (yield-device (device <irrlicht-device>))
+ (let ((yield (get-irrlicht-proc "yield" device)))
+ (yield device)))
-(export create-device get-gui-environment get-scene-manager get-video-driver set-window-caption!)
+(export <irrlicht-device> 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)