(define-module (irrlicht irr)
#:use-module (oop goops)
#:use-module (irrlicht base)
- #:use-module (irrlicht foreign)
- #:use-module (irrlicht gui)
- #:use-module (irrlicht scene)
- #:use-module (irrlicht video))
+ #:use-module (irrlicht foreign))
;; IReferenceCounted
-(define-class <reference-counted> (<irrlicht-base>))
+(define-class <reference-counted> (<irrlicht-base>)
+ (irr-class #:init-value "IReferenceCounted"))
-(export <reference-counted>)
+(define-method (drop! (obj <reference-counted>))
+ (let ((drop (get-irrlicht-proc "drop" obj)))
+ (drop obj)))
+
+(export <reference-counted> drop!)
+
+
+;; SEvent
+(define-class <event> (<irrlicht-base>)
+ (irr-class #:init-value "SEvent"))
+
+(define-method (get-event-key (event <event>))
+ (let ((SKeyInput_Key (get-irrlicht-proc "SKeyInput_Key" event)))
+ (SKeyInput_Key event)))
+
+(define-method (get-event-key-pressed (event <event>))
+ (let ((SKeyInput_PressedDown (get-irrlicht-proc "SKeyInput_PressedDown" event)))
+ (SKeyInput_PressedDown event)))
+
+(define-method (get-event-type (event <event>))
+ (let ((EventType (get-irrlicht-proc "EventType" event)))
+ (EventType event)))
+
+(export <event> get-event-key get-event-key-pressed get-event-type)
;; IEventReceiver
-(define-class <event-receiver> (<irrlicht-base>))
-
-(export <event-receiver>)
-
-
-;; IrrlichtDevice
-(define-class <irrlicht-device> (<reference-counted>))
-
-(define* (create-device #:key
- (device-type 'software)
- (window-size '(640 480))
- (bits 16)
- (fullscreen #f)
- (stencilbuffer #f)
- (vsync #f)
- (receiver (make <event-receiver>)))
- (if (not (is-a? receiver <event-receiver>))
- (error
- "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))))
-
-(define-method (get-gui-environment (device <irrlicht-device>))
- (make <gui-environment>
- #:irr-pointer (irr_IrrlichtDevice_getGUIEnvironment (irr-pointer device))))
-
-(define-method (get-scene-manager (device <irrlicht-device>))
- (make <scene-manager>
- #:irr-pointer (irr_IrrlichtDevice_getSceneManager (irr-pointer device))))
-
-(define-method (get-video-driver (device <irrlicht-device>))
- (make <video-driver>
- #:irr-pointer (irr_IrrlichtDevice_getVideoDriver (irr-pointer device))))
-
-(define-method (set-window-caption! (device <irrlicht-device>) text)
- (irr_IrrlichtDevice_setWindowCaption (irr-pointer device) text))
-
-(export create-device get-gui-environment get-scene-manager get-video-driver set-window-caption!)
+(define-class <event-receiver> (<irrlicht-base>)
+ (irr-class #:init-value "IEventReceiver"))
+
+(define (make-event-receiver proc-on-event)
+ (let ((IEventReceiver_make (get-irrlicht-proc "IEventReceiver_make")))
+ (IEventReceiver_make proc-on-event)))
+
+(export <event-receiver> make-event-receiver)
+
+
+;; SKeyMap
+(define-class <key-map> (<irrlicht-base>)
+ (irr-class #:init-value "SKeyMap"))
+
+(export <key-map>)
+
+
+;; ITimer
+(define-class <timer> (<reference-counted>)
+ (irr-class #:init-value "ITimer"))
+
+(define-method (get-time (timer <timer>))
+ (let ((getTime (get-irrlicht-proc "getTime" timer)))
+ (getTime timer)))
+
+(export <timer> get-time)