]> git.jsancho.org Git - guile-irrlicht.git/blobdiff - src/device.cpp
Some doc
[guile-irrlicht.git] / src / device.cpp
index 55c752fec4b1866a097dfd86a2169601d91297c2..02edd859953a99f654dcb281ef9a96a03e83e6bb 100644 (file)
@@ -25,7 +25,7 @@
 #include "dimension2d.h"
 #include "driver-types.h"
 #include "gsubr.h"
-#include "wchar.h"
+#include "wrapped.h"
 
 using namespace irr;
 
@@ -45,70 +45,77 @@ irr_createDevice (SCM device_type,
                   scm_to_bool (fullscreen),
                   scm_to_bool (stencilbuffer),
                   scm_to_bool (vsync),
-                  (IEventReceiver*)scm_to_pointer (receiver));
-  return scm_from_pointer ((void*)device, NULL);
+                  (IEventReceiver*)scm_to_irr_pointer (receiver));
+  return scm_from_irr_pointer ("<irrlicht-device>", (void*) device);
+}
+
+SCM
+IrrlichtDevice_closeDevice (SCM device)
+{
+  ((IrrlichtDevice*)scm_to_irr_pointer (device))->closeDevice ();
+  return SCM_UNSPECIFIED;
 }
 
 SCM
 IrrlichtDevice_getCursorControl (SCM device)
 {
   gui::ICursorControl* cursor_control =
-    ((IrrlichtDevice*)scm_to_pointer (device))->getCursorControl ();
-  return scm_from_pointer ((void*)cursor_control, NULL);
+    ((IrrlichtDevice*)scm_to_irr_pointer (device))->getCursorControl ();
+  return scm_from_irr_pointer ("<cursor-control>", (void*) cursor_control);
 }
 
 SCM
 IrrlichtDevice_getFileSystem (SCM device)
 {
   io::IFileSystem* file_system =
-    ((IrrlichtDevice*)scm_to_pointer (device))->getFileSystem ();
-  return scm_from_pointer ((void*)file_system, NULL);
+    ((IrrlichtDevice*)scm_to_irr_pointer (device))->getFileSystem ();
+  return scm_from_irr_pointer ("<file-system>", (void*) file_system);
 }
 
 SCM
 IrrlichtDevice_getGUIEnvironment (SCM device)
 {
   gui::IGUIEnvironment* gui_env =
-    ((IrrlichtDevice*)scm_to_pointer (device))->getGUIEnvironment ();
-  return scm_from_pointer ((void*)gui_env, NULL);
+    ((IrrlichtDevice*)scm_to_irr_pointer (device))->getGUIEnvironment ();
+  return scm_from_irr_pointer ("<gui-environment>", (void*) gui_env);
 }
 
 SCM
 IrrlichtDevice_getSceneManager (SCM device)
 {
   scene::ISceneManager* manager =
-    ((IrrlichtDevice*)scm_to_pointer (device))->getSceneManager ();
-  return scm_from_pointer ((void*)manager, NULL);
+    ((IrrlichtDevice*)scm_to_irr_pointer (device))->getSceneManager ();
+  return scm_from_irr_pointer ("<scene-manager>", (void*) manager);
 }
 
 SCM
 IrrlichtDevice_getTimer (SCM device)
 {
   ITimer* timer =
-    ((IrrlichtDevice*)scm_to_pointer (device))->getTimer ();
-  return scm_from_pointer ((void*)timer, NULL);
+    ((IrrlichtDevice*)scm_to_irr_pointer (device))->getTimer ();
+  return scm_from_irr_pointer ("<timer>", (void*) timer);
 }
 
 SCM
 IrrlichtDevice_getVideoDriver (SCM device)
 {
   video::IVideoDriver* driver =
-    ((IrrlichtDevice*)scm_to_pointer (device))->getVideoDriver ();
-  return scm_from_pointer ((void*)driver, NULL);
+    ((IrrlichtDevice*)scm_to_irr_pointer (device))->getVideoDriver ();
+  return scm_from_irr_pointer ("<video-driver>", (void*) driver);
 }
 
 SCM
 IrrlichtDevice_isWindowActive (SCM device)
 {
   return scm_from_bool
-    (((IrrlichtDevice*)scm_to_pointer (device))->isWindowActive ());
+    (((IrrlichtDevice*)scm_to_irr_pointer (device))->isWindowActive ());
 }
 
 SCM
 IrrlichtDevice_run (SCM device)
 {
   return scm_from_bool
-    (((IrrlichtDevice*)scm_to_pointer (device))->run ());
+    (((IrrlichtDevice*)scm_to_irr_pointer (device))->run ());
 }
 
 template <typename TEventReceiver>
@@ -116,8 +123,8 @@ SCM
 IrrlichtDevice_setEventReceiver (SCM device,
                                  SCM receiver)
 {
-  ((IrrlichtDevice*)scm_to_pointer (device))->
-    setEventReceiver ((TEventReceiver)scm_to_pointer (receiver));
+  ((IrrlichtDevice*)scm_to_irr_pointer (device))->
+    setEventReceiver ((TEventReceiver)scm_to_irr_pointer (receiver));
   return SCM_UNSPECIFIED;
 }
 
@@ -125,7 +132,7 @@ SCM
 IrrlichtDevice_setResizable (SCM device,
                              SCM resize)
 {
-  ((IrrlichtDevice*)scm_to_pointer (device))->
+  ((IrrlichtDevice*)scm_to_irr_pointer (device))->
     setResizable (scm_to_bool (resize));
   return SCM_UNSPECIFIED;
 }
@@ -134,15 +141,16 @@ SCM
 IrrlichtDevice_setWindowCaption (SCM device,
                                  SCM text)
 {
-  ((IrrlichtDevice*)scm_to_pointer (device))->
-    setWindowCaption (scm_to_wide_char_string (text));
+  wchar_t* wtext = (wchar_t*) scm_to_utf32_string (text);
+  ((IrrlichtDevice*)scm_to_irr_pointer (device))->setWindowCaption (wtext);
+  free (wtext);
   return SCM_UNSPECIFIED;
 }
 
 SCM
 IrrlichtDevice_yield (SCM device)
 {
-  ((IrrlichtDevice*)scm_to_pointer (device))->yield ();
+  ((IrrlichtDevice*)scm_to_irr_pointer (device))->yield ();
   return SCM_UNSPECIFIED;
 }
 
@@ -150,6 +158,7 @@ void
 init_device (void)
 {
   DEFINE_GSUBR ("createDevice", 7, 0, 0, irr_createDevice);
+  DEFINE_GSUBR ("IrrlichtDevice_closeDevice", 1, 0, 0, IrrlichtDevice_closeDevice);
   DEFINE_GSUBR ("IrrlichtDevice_getCursorControl", 1, 0, 0, IrrlichtDevice_getCursorControl);
   DEFINE_GSUBR ("IrrlichtDevice_getFileSystem", 1, 0, 0, IrrlichtDevice_getFileSystem);
   DEFINE_GSUBR ("IrrlichtDevice_getGUIEnvironment", 1, 0, 0, IrrlichtDevice_getGUIEnvironment);