X-Git-Url: https://git.jsancho.org/?a=blobdiff_plain;f=src%2Fdevice.cpp;h=96442c7e3797300654efd3964cb0901c94b3bdd8;hb=56bdd24ab9463c0bba4d5be87b2933e6a817ccee;hp=3b5b9b9f76d1b820c755e6580b71d7db9bd9dd51;hpb=3394d6066c9092a5444c9273f52cea01e2eaf10f;p=guile-irrlicht.git diff --git a/src/device.cpp b/src/device.cpp index 3b5b9b9..96442c7 100644 --- a/src/device.cpp +++ b/src/device.cpp @@ -25,6 +25,9 @@ #include "device.h" #include "dimension2d.h" #include "driver-types.h" +#include "event-receiver.h" +#include "gsubr.h" +#include "timer.h" #include "wchar.h" #include "wrapped.h" @@ -34,10 +37,12 @@ extern "C" { init_device (void) { init_device_type (); - scm_c_define_gsubr ("create-device", 0, 0, 1, (scm_t_subr)irr_createDevice); - scm_c_define_gsubr ("run", 1, 0, 0, (scm_t_subr)irr_run); - scm_c_define_gsubr ("set-window-caption!", 2, 0, 0, (scm_t_subr)irr_setWindowCaption); - scm_c_export ("create-device", "run", "set-window-caption!", NULL); + DEFINE_GSUBR ("create-device", 0, 0, 1, irr_createDevice); + DEFINE_GSUBR ("get-timer", 1, 0, 0, irr_getTimer); + DEFINE_GSUBR ("is-window-active?", 1, 0, 0, irr_isWindowActive); + DEFINE_GSUBR ("run", 1, 0, 0, irr_run); + DEFINE_GSUBR ("set-window-caption!", 2, 0, 0, irr_setWindowCaption); + DEFINE_GSUBR ("yield", 1, 0, 0, irr_yield); } DEFINE_WRAPPED_TYPE (irr::IrrlichtDevice*, "device", @@ -51,10 +56,10 @@ extern "C" { SCM window_size = scm_list_2 (scm_from_uint32 (640), scm_from_uint32 (480)); SCM bits = scm_from_uint32 (16); - SCM fullscreen = scm_from_bool (0); - SCM stencilbuffer = scm_from_bool (0); - SCM vsync = scm_from_bool (0); - SCM receiver = scm_from_bool (0); + SCM fullscreen = SCM_BOOL_F; + SCM stencilbuffer = SCM_BOOL_F; + SCM vsync = SCM_BOOL_F; + SCM receiver = SCM_BOOL_F; scm_c_bind_keyword_arguments ("create-device", rest, (scm_t_keyword_arguments_flags)0, scm_from_utf8_keyword ("device-type"), &device_type, @@ -72,10 +77,25 @@ extern "C" { scm_to_uint32 (bits), scm_to_bool (fullscreen), scm_to_bool (stencilbuffer), - scm_to_bool (vsync)); + scm_to_bool (vsync), + scm_is_false (receiver) ? 0 : unwrap_event_receiver (receiver)); return wrap_device (device); } + SCM + irr_getTimer (SCM wrapped_device) + { + irr::IrrlichtDevice* device = unwrap_device (wrapped_device); + return wrap_timer (device->getTimer ()); + } + + SCM + irr_isWindowActive (SCM wrapped_device) + { + irr::IrrlichtDevice* device = unwrap_device (wrapped_device); + return scm_from_bool (device->isWindowActive ()); + } + SCM irr_run (SCM wrapped_device) { @@ -92,4 +112,12 @@ extern "C" { return SCM_UNSPECIFIED; } + SCM + irr_yield (SCM wrapped_device) + { + irr::IrrlichtDevice* device = unwrap_device (wrapped_device); + device->yield (); + return SCM_UNSPECIFIED; + } + }