diff --git a/input/driver.hpp b/input/driver.hpp index f8bf9ce09..d95fa206e 100644 --- a/input/driver.hpp +++ b/input/driver.hpp @@ -2,38 +2,12 @@ #define MANGLE_INPUT_DRIVER_H #include "../tools/shared_ptr.hpp" +#include "event.hpp" namespace Mangle { namespace Input { - /** Generic callback for input events. The meaning of the - parameters depend on the system producing the events. - */ - struct Event - { - /// Event types - enum EventType - { - EV_Unknown = -1, // Unknown event type - EV_KeyDown = 1, // Key, mouse or other button was pressed - EV_KeyUp = 2, // Key, mouse or other button was released - EV_MouseMove = 3, // Mouse movement (all axis movement?) - EV_Other = 4 // Other event - }; - - /** - Called upon all events. The first parameter give the event - type, the second gives additional data (usually the local - keysym as defined by the driver), and the pointer points to - the full custom event structure provided by the driver (the - type may vary depending on the EventType, this is defined in - the Driver documentation.) - */ - virtual void event(EventType type, int index, const void *p) = 0; - virtual ~Event() {} - }; - /** Input::Driver is the main interface to any input system that handles keyboard and/or mouse input, along with any other input source like joysticks. @@ -78,7 +52,7 @@ namespace Mangle can also be called from the outside to "fake" events from this driver. */ - void makeEvent(Event::EventType type, int index, const void *p=NULL) + void makeEvent(Event::Type type, int index, const void *p=NULL) { if(event) event->event(type,index,p); diff --git a/input/event.hpp b/input/event.hpp new file mode 100644 index 000000000..5948653bd --- /dev/null +++ b/input/event.hpp @@ -0,0 +1,36 @@ +#ifndef MANGLE_INPUT_EVENT_H +#define MANGLE_INPUT_EVENT_H + +namespace Mangle +{ + namespace Input + { + /** Generic callback for input events. The meaning of the + parameters depend on the system producing the events. + */ + struct Event + { + /// Event types + enum Type + { + EV_Unknown = -1, // Unknown event type + EV_KeyDown = 1, // Key, mouse or other button was pressed + EV_KeyUp = 2, // Key, mouse or other button was released + EV_MouseMove = 3, // Mouse movement (all axis movement?) + EV_Other = 4 // Other event + }; + + /** + Called upon all events. The first parameter give the event + type, the second gives additional data (usually the local + keysym as defined by the driver), and the pointer points to + the full custom event structure provided by the driver (the + type may vary depending on the EventType, this is defined in + the Driver documentation.) + */ + virtual void event(Type type, int index, const void *p) = 0; + virtual ~Event() {} + }; + } +} +#endif diff --git a/input/servers/sdl_driver.cpp b/input/servers/sdl_driver.cpp index f1d92dd41..93884a6e6 100644 --- a/input/servers/sdl_driver.cpp +++ b/input/servers/sdl_driver.cpp @@ -10,7 +10,7 @@ void SDLDriver::capture() SDL_Event evt; while(SDL_PollEvent(&evt)) { - Event::EventType type = Event::EV_Unknown; + Event::Type type = Event::EV_Unknown; int index = -1; switch(evt.type) diff --git a/input/tests/common.cpp b/input/tests/common.cpp index 33f2188e9..47a0c53de 100644 --- a/input/tests/common.cpp +++ b/input/tests/common.cpp @@ -8,7 +8,7 @@ Driver *input; struct MyCB : Event { - void event(Event::EventType type, int i, const void *p) + void event(Event::Type type, int i, const void *p) { cout << "got event: type=" << type << " index=" << i << endl; }