X-Git-Url: https://git.jsancho.org/?a=blobdiff_plain;ds=sidebyside;f=src%2FIrrlichtDevice.cpp;h=a220cac5a3e91cfa2681250ecee1b611175dcdcd;hb=21f12bf4ba8c031b36784e1e0a479535f477cc59;hp=82b729d040e5f2f580f2d2c47ef7808808a0648f;hpb=56de371557044d3b7acc14cb94cc46641be906d9;p=guile-irrlicht.git diff --git a/src/IrrlichtDevice.cpp b/src/IrrlichtDevice.cpp index 82b729d..a220cac 100644 --- a/src/IrrlichtDevice.cpp +++ b/src/IrrlichtDevice.cpp @@ -37,6 +37,7 @@ extern "C" { { init_device_type (); scm_c_define_gsubr ("create-device", 7, 0, 0, (scm_t_subr)irr_createDevice); + scm_c_define_gsubr ("device-drop!", 1, 0, 0, (scm_t_subr)irr_deviceDrop); scm_c_define_gsubr ("get-gui-environment", 1, 0, 0, (scm_t_subr)irr_getGUIEnvironment); scm_c_define_gsubr ("get-scene-manager", 1, 0, 0, (scm_t_subr)irr_getSceneManager); scm_c_define_gsubr ("get-video-driver", 1, 0, 0, (scm_t_subr)irr_getVideoDriver); @@ -66,34 +67,41 @@ extern "C" { } SCM - irr_getGUIEnvironment (SCM device_obj) + irr_deviceDrop (SCM wrapped_device) { - irr::IrrlichtDevice* device = unwrap_device (device_obj); - irr::gui::IGUIEnvironment* gui_environment = device->getGUIEnvironment(); + irr::IrrlichtDevice* device = unwrap_device (wrapped_device); + return scm_from_bool (device->drop ()); + } + + SCM + irr_getGUIEnvironment (SCM wrapped_device) + { + irr::IrrlichtDevice* device = unwrap_device (wrapped_device); + irr::gui::IGUIEnvironment* gui_environment = device->getGUIEnvironment (); return wrap_gui_environment (gui_environment); } SCM - irr_getSceneManager (SCM device_obj) + irr_getSceneManager (SCM wrapped_device) { - irr::IrrlichtDevice* device = unwrap_device (device_obj); - irr::scene::ISceneManager* scene_manager = device->getSceneManager(); + irr::IrrlichtDevice* device = unwrap_device (wrapped_device); + irr::scene::ISceneManager* scene_manager = device->getSceneManager (); return wrap_scene_manager (scene_manager); } SCM - irr_getVideoDriver (SCM device_obj) + irr_getVideoDriver (SCM wrapped_device) { - irr::IrrlichtDevice* device = unwrap_device (device_obj); - irr::video::IVideoDriver* driver = device->getVideoDriver(); + irr::IrrlichtDevice* device = unwrap_device (wrapped_device); + irr::video::IVideoDriver* driver = device->getVideoDriver (); return wrap_video_driver (driver); } SCM - irr_setWindowCaption (SCM device_obj, + irr_setWindowCaption (SCM wrapped_device, SCM text) { - irr::IrrlichtDevice* device = unwrap_device (device_obj); + irr::IrrlichtDevice* device = unwrap_device (wrapped_device); device->setWindowCaption (scm_to_wide_char_string (text)); return SCM_UNSPECIFIED; }