diff options
| author | Eleni Maria Stea <elene.mst@gmail.com> | 2013-02-23 01:22:10 +0200 |
|---|---|---|
| committer | Eleni Maria Stea <elene.mst@gmail.com> | 2013-02-23 01:22:10 +0200 |
| commit | 6dc42c0e7292d6d94de640ddd7de3ee5c808e9c2 (patch) | |
| tree | 638a8b4eaed9c1540618733c09e12f7c96140392 /src/fbdev/event.cc | |
| parent | 4047a2dc058e7e54e4ff95311fb556ae8eeeedb9 (diff) | |
added SDL backend for easier testing
Diffstat (limited to 'src/fbdev/event.cc')
| -rw-r--r-- | src/fbdev/event.cc | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/src/fbdev/event.cc b/src/fbdev/event.cc new file mode 100644 index 0000000..611ec3c --- /dev/null +++ b/src/fbdev/event.cc @@ -0,0 +1,39 @@ +#ifdef WINNIE_FBDEV +#include <stdio.h> + +#include <errno.h> +#include <unistd.h> +#include <sys/select.h> + +#include "event.h" +#include "wm.h" +#include "keyboard.h" +#include "mouse.h" + +void process_events() +{ + int keyb_fd = get_keyboard_fd(); + int mouse_fd = get_mouse_fd(); + + for(;;) { + wm->process_windows(); + + fd_set read_set; + + FD_ZERO(&read_set); + FD_SET(keyb_fd, &read_set); + FD_SET(mouse_fd, &read_set); + + int maxfd = keyb_fd > mouse_fd ? keyb_fd : mouse_fd; + + while(select(maxfd + 1, &read_set, 0, 0, 0) == -1 && errno == EINTR); + + if(FD_ISSET(keyb_fd, &read_set)) { + process_keyboard_event(); + } + if(FD_ISSET(mouse_fd, &read_set)) { + process_mouse_event(); + } + } +} +#endif // WINNIE_FBDEV |
