2016-11-05 22:00:23 +01:00
|
|
|
//---
|
|
|
|
//
|
|
|
|
// gint core module: events
|
|
|
|
//
|
|
|
|
// Finally some user-friendly API.
|
|
|
|
//
|
|
|
|
//---
|
|
|
|
|
|
|
|
#ifndef _EVENTS_H
|
|
|
|
#define _EVENTS_H
|
|
|
|
|
|
|
|
/*
|
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
|
|
|
{
|
|
|
|
EventType_None = 0,
|
|
|
|
ET_None = EventType_None,
|
|
|
|
|
|
|
|
EventType_User = 1,
|
|
|
|
ET_User = EventType_User,
|
|
|
|
|
|
|
|
EventType_KeyPressed = 2,
|
|
|
|
ET_KeyPress = EventType_KeyPressed,
|
|
|
|
|
2017-02-25 23:19:35 +01:00
|
|
|
EventType_KeyRepeated = 3,
|
|
|
|
ET_KeyRepeat = EventType_KeyRepeated,
|
|
|
|
|
|
|
|
EventType_KeyReleased = 4,
|
2016-11-05 22:00:23 +01:00
|
|
|
ET_KeyRel = EventType_KeyReleased,
|
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
|
|
|
|
about the event is implicitly defined by the type attribute.
|
|
|
|
*/
|
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
|
|
|
|
{
|
|
|
|
// For ET_User.
|
|
|
|
void *data;
|
2017-02-25 23:19:35 +01:00
|
|
|
// For ET_KeyPress, ET_KeyRepeat and ET_KeyRel.
|
2016-11-05 22:00:23 +01:00
|
|
|
int key;
|
|
|
|
};
|
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
|