2016-11-05 22:00:23 +01:00
|
|
|
//---
|
|
|
|
//
|
|
|
|
// gint core module: events
|
|
|
|
//
|
2017-03-26 18:38:32 +02:00
|
|
|
// Finally some user-friendly API. This module is in charge of managing
|
|
|
|
// the event queue. The waitevent() function should be particularly useful
|
|
|
|
// in program main loops to record key presses and releases in real-time
|
|
|
|
// games.
|
|
|
|
//
|
|
|
|
// Other functions such as the getkey() of the keyboard module provide
|
|
|
|
// more advanced features such as SHIFT and ALPHA modifiers, backlight
|
|
|
|
// control for instance; these functions rely on this module and they
|
|
|
|
// ignore all events that they do not handle. If you want to catch several
|
|
|
|
// types of events (eg. keyboard and serial communication), then you need
|
|
|
|
// to use directly this module.
|
2016-11-05 22:00:23 +01:00
|
|
|
//
|
|
|
|
//---
|
|
|
|
|
|
|
|
#ifndef _EVENTS_H
|
|
|
|
#define _EVENTS_H
|
|
|
|
|
2017-03-01 11:07:28 +01:00
|
|
|
#include <timer.h>
|
|
|
|
|
2016-11-05 22:00:23 +01:00
|
|
|
/*
|
2017-02-25 23:19:35 +01:00
|
|
|
event_type_t
|
2016-11-05 22:00:23 +01:00
|
|
|
Something user programs will surely use most often.
|
|
|
|
*/
|
2017-02-25 23:19:35 +01:00
|
|
|
typedef enum
|
2016-11-05 22:00:23 +01:00
|
|
|
{
|
2017-03-26 18:38:32 +02:00
|
|
|
// Specific events.
|
|
|
|
event_none = 0,
|
|
|
|
event_user = 1,
|
2016-11-05 22:00:23 +01:00
|
|
|
|
2017-03-26 18:38:32 +02:00
|
|
|
// Keyboard events.
|
|
|
|
event_key_press = 2,
|
|
|
|
event_key_repeat = 3,
|
|
|
|
event_key_release = 4,
|
2017-02-25 23:19:35 +01:00
|
|
|
|
2017-03-26 18:38:32 +02:00
|
|
|
// Other events.
|
|
|
|
event_timer_underflow = 5,
|
2017-02-25 23:19:35 +01:00
|
|
|
|
|
|
|
} event_type_t;
|
2016-11-05 22:00:23 +01:00
|
|
|
|
|
|
|
/*
|
2017-02-25 23:19:35 +01:00
|
|
|
event_t
|
2016-11-05 22:00:23 +01:00
|
|
|
Wake up, something's going on. The union member that holds information
|
2017-03-26 18:38:32 +02:00
|
|
|
about the event is specified by the type attribute.
|
2016-11-05 22:00:23 +01:00
|
|
|
*/
|
2017-02-25 23:19:35 +01:00
|
|
|
typedef struct
|
2016-11-05 22:00:23 +01:00
|
|
|
{
|
2017-02-25 23:19:35 +01:00
|
|
|
event_type_t type;
|
2016-11-05 22:00:23 +01:00
|
|
|
|
|
|
|
union
|
|
|
|
{
|
2017-03-26 18:38:32 +02:00
|
|
|
// For event_user.
|
2016-11-05 22:00:23 +01:00
|
|
|
void *data;
|
2017-03-26 18:38:32 +02:00
|
|
|
// For event_key_press, event_key_repeat and event_key_release.
|
2016-11-05 22:00:23 +01:00
|
|
|
int key;
|
2017-03-26 18:38:32 +02:00
|
|
|
// For event_timer_underflow.
|
2017-03-01 11:07:28 +01:00
|
|
|
timer_t *timer;
|
2016-11-05 22:00:23 +01:00
|
|
|
};
|
2017-02-25 23:19:35 +01:00
|
|
|
|
|
|
|
} event_t;
|
2016-11-05 22:00:23 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//---
|
|
|
|
// Event management.
|
|
|
|
//---
|
|
|
|
|
|
|
|
/*
|
|
|
|
event_push()
|
|
|
|
Queues a user-defined event, allowing it to be retrieved by getevent()
|
|
|
|
or pollevent() later. Most often you will not need to use this, as
|
|
|
|
system events are automatically queued. Pushing ET_None events is not
|
|
|
|
allowed.
|
|
|
|
Returns non-zero on error.
|
|
|
|
*/
|
2017-02-25 23:19:35 +01:00
|
|
|
int event_push(event_t event);
|
2016-11-05 22:00:23 +01:00
|
|
|
|
|
|
|
/*
|
2017-02-25 23:19:35 +01:00
|
|
|
waitevent()
|
2016-11-05 22:00:23 +01:00
|
|
|
Returns the next event. If no one is available, waits for something to
|
|
|
|
happen. This function uses low-level sleep and should be preferred to
|
|
|
|
active waiting using loops.
|
|
|
|
*/
|
2017-02-25 23:19:35 +01:00
|
|
|
event_t waitevent(void);
|
2016-11-05 22:00:23 +01:00
|
|
|
|
|
|
|
/*
|
|
|
|
pollevent()
|
|
|
|
Returns the next event. If no one is available, returns an event whose
|
|
|
|
type is ET_None. This function always returns immediately.
|
|
|
|
*/
|
2017-02-25 23:19:35 +01:00
|
|
|
event_t pollevent(void);
|
2016-11-05 22:00:23 +01:00
|
|
|
|
|
|
|
#endif // _EVENTS_H
|