]> git.jsancho.org Git - guile-irrlicht.git/commitdiff
is-window-active? yield
authorJavier Sancho <jsf@jsancho.org>
Sat, 21 Mar 2020 19:18:58 +0000 (20:18 +0100)
committerJavier Sancho <jsf@jsancho.org>
Sat, 21 Mar 2020 19:18:58 +0000 (20:18 +0100)
src/device.cpp
src/device.h

index 3b5b9b9f76d1b820c755e6580b71d7db9bd9dd51..41d6193344190efb3fc45c536a513a82308d09fd 100644 (file)
@@ -35,9 +35,12 @@ extern "C" {
   {
     init_device_type ();
     scm_c_define_gsubr ("create-device", 0, 0, 1, (scm_t_subr)irr_createDevice);
+    scm_c_define_gsubr ("is-window-active?", 1, 0, 0, (scm_t_subr)irr_isWindowActive);
     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);
+    scm_c_define_gsubr ("yield", 1, 0, 0, (scm_t_subr)irr_yield);
+    scm_c_export ("create-device", "is-window-active?", "run",
+                  "set-window-caption!", "yield", NULL);
   }
 
   DEFINE_WRAPPED_TYPE (irr::IrrlichtDevice*, "device",
@@ -76,6 +79,13 @@ extern "C" {
     return wrap_device (device);
   }
 
+  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 +102,12 @@ extern "C" {
     return SCM_UNSPECIFIED;
   }
 
+  SCM
+  irr_yield (SCM wrapped_device)
+  {
+    irr::IrrlichtDevice* device = unwrap_device (wrapped_device);
+    device->yield ();
+    return SCM_UNSPECIFIED;
+  }
+
 }
index 31195c6deb9d96b891e9e9989cf44436530d6ddb..ec5875acb9d0c5c29a606aef2b8336554350a75e 100644 (file)
@@ -37,6 +37,9 @@ extern "C" {
   SCM
   irr_createDevice (SCM rest);
 
+  SCM
+  irr_isWindowActive (SCM wrapped_device);
+
   SCM
   irr_run (SCM wrapped_device);
 
@@ -44,6 +47,9 @@ extern "C" {
   irr_setWindowCaption (SCM wrapped_device,
                         SCM text);
 
+  SCM
+  irr_yield (SCM wrapped_device);
+
 }
 
 #endif