]> git.jsancho.org Git - guile-irrlicht.git/blob - src/reference-counted.cpp
b13cbb02f799c656c7c65a652147209d90a4837e
[guile-irrlicht.git] / src / reference-counted.cpp
1 /* guile-irrlicht --- GNU Guile bindings for Irrlicht Engine
2
3    Copyright (C) 2020 Javier Sancho <jsf@jsancho.org>
4
5    This file is part of guile-irrlicht.
6
7    guile-irrlicht is free software; you can redistribute it and/or modify
8    it under the terms of the GNU Lesser General Public License as
9    published by the Free Software Foundation; either version 3 of the
10    License, or (at your option) any later version.
11
12    guile-irrlicht is distributed in the hope that it will be useful, but
13    WITHOUT ANY WARRANTY; without even the implied warranty of
14    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15    General Public License for more details.
16
17    You should have received a copy of the GNU Lesser General Public
18    License along with guile-irrlicht. If not, see
19    <http://www.gnu.org/licenses/>.
20 */
21
22 #include <irrlicht/irrlicht.h>
23 #include <libguile.h>
24
25 #include "device.h"
26 #include "gsubr.h"
27 #include "reference-counted.h"
28 #include "scene-node-animator.h"
29
30 extern "C" {
31
32   DEFINE_WRAPPED_TYPE (irr::IReferenceCounted*, "reference-counted",
33                        init_reference_counted_type, reference_counted_p,
34                        wrap_reference_counted, unwrap_reference_counted);
35
36   void
37   init_reference_counted (void)
38   {
39     init_reference_counted_type ();
40     DEFINE_GSUBR ("drop!", 1, 0, 0, irr_drop);
41   }
42
43   bool
44   is_reference_counted_object (SCM wrapped_obj)
45   {
46     return
47       device_p (wrapped_obj) ||
48       reference_counted_p (wrapped_obj) ||
49       scene_node_animator_p (wrapped_obj);
50   }
51
52   SCM
53   irr_drop (SCM wrapped_obj)
54   {
55     if (is_reference_counted_object (wrapped_obj))
56       {
57         irr::IReferenceCounted* obj = unwrap_reference_counted (wrapped_obj, false);
58         return scm_from_bool (obj->drop ());
59       }
60     else
61       {
62         scm_error (scm_arg_type_key, NULL, "Object cannot be dropped: ~S",
63                    scm_list_1 (wrapped_obj), scm_list_1 (wrapped_obj));
64       }
65   }
66
67 }