]> git.jsancho.org Git - guile-irrlicht.git/blobdiff - irrlicht/foreign.scm
Some doc
[guile-irrlicht.git] / irrlicht / foreign.scm
index aaac04ff08bf812382dbf8c407780f73c90fd503..96cec83bd0dd04c9dfca6a5c5c5757cf07992337 100644 (file)
 
 
 (define-module (irrlicht foreign)
+  #:use-module (system foreign)
   #:use-module (irrlicht base)
-  #:export (get-irrlicht-proc))
+  #:export (get-irrlicht-proc
+            null-object?
+            remember-wrapped
+            mem-wrapped))
 
 ;; We use a hash table to store foreign irrlicht methods related with their
 ;; classes
@@ -28,8 +32,6 @@
 (define remote-proc-table (make-hash-table))
 
 (define (get-irrlicht-proc proc-name . objects)
-  (format #t "Objects: ~a ~a~%" objects irr-class)
-  (format #t "Classes: ~a~%" (map irr-class objects))
   (let* ((name (if (null? objects)
                    proc-name
                    (let ((classes (map irr-class objects)))
              new-proc))
           (else
            proc))))
+
+(define (null-object? object)
+  (null-pointer? (irr-pointer object)))
+
+;; Table for storing foreign irrlicht wrapped objects by its pointer address
+;; We can recover them later, when we have an address without knowing its type, like in
+;; events case
+(define wrapped-obj-table (make-hash-table))
+
+(define (remember-wrapped object)
+  (or (hash-ref wrapped-obj-table
+                (pointer-address (irr-pointer object)))
+      object))
+
+(define (mem-wrapped object)
+  (hash-set! wrapped-obj-table
+             (pointer-address (irr-pointer object))
+             object)
+  object)