From b298e30f299d7c0b91c00f2455b4bc1efabe62e3 Mon Sep 17 00:00:00 2001 From: Javier Sancho Date: Thu, 7 May 2020 12:01:53 +0200 Subject: [PATCH] animated-mesh --- src/animated-mesh.cpp | 47 +++++++++++++++---------------------------- src/animated-mesh.h | 14 ++++++------- 2 files changed, 22 insertions(+), 39 deletions(-) diff --git a/src/animated-mesh.cpp b/src/animated-mesh.cpp index 327deb0..b79f196 100644 --- a/src/animated-mesh.cpp +++ b/src/animated-mesh.cpp @@ -23,44 +23,29 @@ #include #include "animated-mesh.h" -#include "animated-mesh-scene-node.h" #include "gsubr.h" -#include "wrapped.h" -extern "C" { - void - init_animated_mesh (void) - { - init_animated_mesh_type (); - DEFINE_GSUBR ("set-animation-speed!", 2, 0, 0, irr_scene_setAnimationSpeed); - } +using namespace irr; - DEFINE_WRAPPED_TYPE (irr::scene::IAnimatedMesh*, "animated-mesh", - init_animated_mesh_type, animated_mesh_p, - wrap_animated_mesh, unwrap_animated_mesh); - SCM - irr_scene_setAnimationSpeed (SCM wrapped_obj, - SCM frames_per_second) - { -#define SET_ANIMATION_SPEED(OBJ) OBJ->setAnimationSpeed (scm_to_double (frames_per_second)); +SCM +irr_scene_IAnimatedMesh_setAnimationSpeed (SCM animated_mesh, + SCM frames_per_second) +{ + ((scene::IAnimatedMesh*)scm_to_pointer (animated_mesh))-> + setAnimationSpeed (scm_to_double (frames_per_second)); + return SCM_UNSPECIFIED; +} + - if (animated_mesh_p (wrapped_obj)) - { - SET_ANIMATION_SPEED (unwrap_animated_mesh (wrapped_obj)); - } - else if (animated_mesh_scene_node_p (wrapped_obj)) - { - SET_ANIMATION_SPEED (unwrap_animated_mesh_scene_node (wrapped_obj)); - } - else - { - scm_error (scm_arg_type_key, NULL, "Cannot set animation speed to object: ~S", - scm_list_1 (wrapped_obj), scm_list_1 (wrapped_obj)); - } +extern "C" { - return SCM_UNSPECIFIED; + void + init_animated_mesh (void) + { + DEFINE_GSUBR ("irr_scene_IAnimatedMesh_setAnimationSpeed", 2, 0, 0, + irr_scene_IAnimatedMesh_setAnimationSpeed); } } diff --git a/src/animated-mesh.h b/src/animated-mesh.h index 4798c31..fd65653 100644 --- a/src/animated-mesh.h +++ b/src/animated-mesh.h @@ -24,20 +24,18 @@ #include #include -#include "wrapped.h" + + +SCM +irr_scene_IAnimatedMesh_setAnimationSpeed (SCM animated_mesh, + SCM frames_per_second); + extern "C" { void init_animated_mesh (void); - DECLARE_WRAPPED_TYPE (irr::scene::IAnimatedMesh*, init_animated_mesh_type, - animated_mesh_p, wrap_animated_mesh, unwrap_animated_mesh); - - SCM - irr_scene_setAnimationSpeed (SCM wrapped_obj, - SCM frames_per_second); - } #endif -- 2.39.5