;;; guile-irrlicht --- FFI bindings for Irrlicht Engine
-;;; Copyright (C) 2019 Javier Sancho <jsf@jsancho.org>
+;;; Copyright (C) 2020 Javier Sancho <jsf@jsancho.org>
;;;
;;; This file is part of guile-irrlicht.
;;;
(define-module (irrlicht irr)
- #:export (drop!))
+ #:use-module (oop goops)
+ #:use-module (irrlicht base)
+ #:use-module (irrlicht foreign))
-(load-extension "libguile-irrlicht" "init_guile_irrlicht")
+
+;; IReferenceCounted
+(define-class <reference-counted> (<irrlicht-base>)
+ (irr-class #:init-value "IReferenceCounted"))
+
+(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-gui-caller (event <event>))
+ (let ((SGUIEvent_Caller (get-irrlicht-proc "SGUIEvent_Caller" event)))
+ (SGUIEvent_Caller event)))
+
+(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-gui-caller get-event-key get-event-key-pressed get-event-type)
+
+
+;; IEventReceiver
+(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)