X-Git-Url: https://git.jsancho.org/?a=blobdiff_plain;f=src%2Fcursor-control.cpp;h=c4893461281fd7ee61e12246b3df1a791e1e0f21;hb=c59d2be798005a3684d75c3f561568ad2cdac9c7;hp=1147eab54191ab35ad655b9ef0c6ce103c5ac8c9;hpb=8876c6e31fddf00f9764d9fe73930d8dc8fc6c4a;p=guile-irrlicht.git diff --git a/src/cursor-control.cpp b/src/cursor-control.cpp index 1147eab..c489346 100644 --- a/src/cursor-control.cpp +++ b/src/cursor-control.cpp @@ -21,55 +21,42 @@ #include #include - #include "cursor-control.h" -#include "device.h" #include "gsubr.h" #include "position2d.h" #include "wrapped.h" -extern "C" { - - void - init_cursor_control (void) - { - init_cursor_control_type (); - DEFINE_GSUBR ("get-cursor-control", 1, 0, 0, irr_getCursorControl); - } - - DEFINE_WRAPPED_TYPE (irr::gui::ICursorControl*, "cursor-control", - init_cursor_control_type, cursor_control_p, - wrap_cursor_control, unwrap_cursor_control); +using namespace irr; - SCM - irr_getCursorControl (SCM wrapped_device) - { - irr::gui::ICursorControl* cursor_control = - unwrap_device (wrapped_device)->getCursorControl (); - return wrap_cursor_control (cursor_control); - } +SCM +ICursorControl_getPosition (SCM cursor_control) +{ + return scm_from_position2d_s32 + (((gui::ICursorControl*)scm_to_irr_pointer (cursor_control))->getPosition ()); +} - SCM - irr_gui_getPosition (SCM wrapped_cursor_control) - { - irr::gui::ICursorControl* control = unwrap_cursor_control (wrapped_cursor_control); - return scm_from_position2d_s32 (control->getPosition ()); - } +SCM +ICursorControl_setPosition (SCM cursor_control, + SCM position) +{ + ((gui::ICursorControl*)scm_to_irr_pointer (cursor_control))-> + setPosition (scm_to_position2d_s32 (position)); + return SCM_UNSPECIFIED; +} - SCM - irr_gui_setPosition (SCM wrapped_cursor_control, - SCM position) - { - irr::gui::ICursorControl* control = unwrap_cursor_control (wrapped_cursor_control); - if (scm_is_integer (scm_car (position)) && scm_is_integer (scm_cadr (position))) - { - control->setPosition (scm_to_position2d_s32 (position)); - } - else - { - control->setPosition (scm_to_position2d_f32 (position)); - } - return SCM_UNSPECIFIED; - } +SCM +ICursorControl_setVisible (SCM cursor_control, + SCM visible) +{ + ((gui::ICursorControl*)scm_to_irr_pointer (cursor_control))-> + setVisible (scm_to_bool (visible)); + return SCM_UNSPECIFIED; +} +void +init_cursor_control (void) +{ + DEFINE_GSUBR ("ICursorControl_getPosition", 1, 0, 0, ICursorControl_getPosition); + DEFINE_GSUBR ("ICursorControl_setPosition", 2, 0, 0, ICursorControl_setPosition); + DEFINE_GSUBR ("ICursorControl_setVisible", 2, 0, 0, ICursorControl_setVisible); }