]> git.jsancho.org Git - guile-irrlicht.git/blob - src/event-receiver.cpp
event-gui-caller
[guile-irrlicht.git] / src / event-receiver.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 "event-receiver.h"
26 #include "gui-element.h"
27 #include "gsubr.h"
28 #include "keycodes.h"
29 #include "wrapped.h"
30
31 extern "C" {
32
33   void
34   init_event_receiver (void)
35   {
36     init_event_receiver_type ();
37     init_event_type ();
38     DEFINE_GSUBR ("event-gui-caller", 1, 0, 0, event_gui_caller);
39     DEFINE_GSUBR ("event-key-input-key", 1, 0, 0, event_key_input_key);
40     DEFINE_GSUBR ("event-key-input-pressed", 1, 0, 0, event_key_input_pressed);
41     DEFINE_GSUBR ("event-type", 1, 0, 0, event_type);
42     DEFINE_GSUBR ("make-event-receiver", 1, 0, 0, make_event_receiver);
43   }
44
45   DEFINE_WRAPPED_TYPE (irr::IEventReceiver*, "event-receiver",
46                        init_event_receiver_type, event_receiver_p,
47                        wrap_event_receiver, unwrap_event_receiver);
48
49   DEFINE_WRAPPED_TYPE (irr::SEvent*, "event",
50                        init_event_type, event_p,
51                        wrap_event, unwrap_event);
52
53   SCM
54   event_gui_caller (SCM event)
55   {
56     return wrap_gui_element (unwrap_event (event)->GUIEvent.Caller);
57   }
58
59   SCM
60   event_key_input_key (SCM event)
61   {
62     return scm_from_key_code (unwrap_event (event)->KeyInput.Key);
63   }
64
65   SCM
66   event_key_input_pressed (SCM event)
67   {
68     return scm_from_bool (unwrap_event (event)->KeyInput.PressedDown);
69   }
70
71   SCM
72   event_type (SCM event)
73   {
74     return scm_from_event_type (unwrap_event (event)->EventType);
75   }
76
77   SCM
78   make_event_receiver (SCM proc_on_event)
79   {
80     class CustomReceiver : public irr::IEventReceiver
81     {
82       SCM scm_on_event;
83
84     public:
85       CustomReceiver (SCM on_event)
86       {
87         scm_on_event = on_event;
88       }
89
90       virtual bool OnEvent (const irr::SEvent& event)
91       {
92         return scm_to_bool (scm_call_1 (scm_on_event, wrap_event ((irr::SEvent*)&event)));
93       }
94     };
95
96     CustomReceiver* receiver = new CustomReceiver (proc_on_event);
97     return wrap_event_receiver (receiver);
98   }
99
100   SCM
101   scm_from_event_type (irr::EEVENT_TYPE event_type)
102   {
103     switch (event_type)
104       {
105       case irr::EET_GUI_EVENT:
106         return scm_from_utf8_symbol ("gui-event");
107         break;
108
109       case irr::EET_MOUSE_INPUT_EVENT:
110         return scm_from_utf8_symbol ("mouse-input-event");
111         break;
112
113       case irr::EET_KEY_INPUT_EVENT:
114         return scm_from_utf8_symbol ("key-input-event");
115         break;
116
117       case irr::EET_JOYSTICK_INPUT_EVENT:
118         return scm_from_utf8_symbol ("joystick-input-event");
119         break;
120
121       case irr::EET_LOG_TEXT_EVENT:
122         return scm_from_utf8_symbol ("log-text-event");
123         break;
124
125       case irr::EET_USER_EVENT:
126         return scm_from_utf8_symbol ("user-event");
127         break;
128
129       default:
130         SCM type = scm_from_uint (event_type);
131         scm_error (scm_arg_type_key, NULL, "Wrong event type: ~S",
132                    scm_list_1 (type), scm_list_1 (type));
133       }
134   }
135
136 }