]> git.jsancho.org Git - guile-irrlicht.git/blobdiff - src/animated-mesh-scene-node.cpp
Some doc
[guile-irrlicht.git] / src / animated-mesh-scene-node.cpp
index 27f3872103a41d237ed358dae2d55ffb69f3b0d7..e63541bcfd2692ebb9a260d02150abebd7a0a2fb 100644 (file)
 
 #include <irrlicht/irrlicht.h>
 #include <libguile.h>
-
 #include "animated-mesh-md2.h"
 #include "animated-mesh-scene-node.h"
 #include "gsubr.h"
 #include "wrapped.h"
 
-extern "C" {
-
-  void
-  init_animated_mesh_scene_node (void)
-  {
-    init_animated_mesh_scene_node_type ();
-    DEFINE_GSUBR ("set-frame-loop!", 3, 0, 0, irr_scene_setFrameLoop);
-    DEFINE_GSUBR ("set-md2-animation!", 2, 0, 0, irr_scene_setMD2Animation);
-  }
+using namespace irr;
 
-  DEFINE_WRAPPED_TYPE (irr::scene::IAnimatedMeshSceneNode*, "animated-mesh-scene-node",
-                       init_animated_mesh_scene_node_type, animated_mesh_scene_node_p,
-                       wrap_animated_mesh_scene_node, unwrap_animated_mesh_scene_node);
+SCM
+IAnimatedMeshSceneNode_setAnimationSpeed (SCM animated_mesh_scene_node,
+                                          SCM frames_per_second)
+{
+  scene::IAnimatedMeshSceneNode* node =
+    (scene::IAnimatedMeshSceneNode*) scm_to_irr_pointer (animated_mesh_scene_node);
+  node->setAnimationSpeed (scm_to_double (frames_per_second));
+  return SCM_UNSPECIFIED;
+}
 
-  SCM
-  irr_scene_setFrameLoop (SCM wrapped_animated_mesh_scene_node,
-                          SCM begin,
-                          SCM end)
-  {
-    return scm_from_bool
-      (unwrap_animated_mesh_scene_node (wrapped_animated_mesh_scene_node)->
-       setFrameLoop (scm_to_int32 (begin),
-                     scm_to_int32 (end)));
-  }
+SCM
+IAnimatedMeshSceneNode_setFrameLoop (SCM animated_mesh_scene_node,
+                                     SCM begin,
+                                     SCM end)
+{
+  return scm_from_bool
+    (((scene::IAnimatedMeshSceneNode*)scm_to_irr_pointer (animated_mesh_scene_node))->
+     setFrameLoop (scm_to_int32 (begin),
+                   scm_to_int32 (end)));
+}
 
-  SCM
-  irr_scene_setMD2Animation (SCM wrapped_animated_mesh_scene_node,
-                             SCM anim)
-  {
-    return scm_from_bool
-      (unwrap_animated_mesh_scene_node (wrapped_animated_mesh_scene_node)->
-       setMD2Animation (scm_to_md2_animation_type (anim)));
-  }
+SCM
+IAnimatedMeshSceneNode_setMD2Animation (SCM animated_mesh_scene_node,
+                                        SCM anim)
+{
+  return scm_from_bool
+    (((scene::IAnimatedMeshSceneNode*)scm_to_irr_pointer (animated_mesh_scene_node))->
+     setMD2Animation (scm_to_md2_animation_type (anim)));
+}
 
+void
+init_animated_mesh_scene_node (void)
+{
+  DEFINE_GSUBR ("IAnimatedMeshSceneNode_setAnimationSpeed", 2, 0, 0,
+                IAnimatedMeshSceneNode_setAnimationSpeed);
+  DEFINE_GSUBR ("IAnimatedMeshSceneNode_setFrameLoop", 3, 0, 0,
+                IAnimatedMeshSceneNode_setFrameLoop);
+  DEFINE_GSUBR ("IAnimatedMeshSceneNode_setMD2Animation", 2, 0, 0,
+                IAnimatedMeshSceneNode_setMD2Animation);
 }