Mercurial > projects > mde
view mde/events.d @ 63:66d555da083e
Moved many modules/packages to better reflect usage.
author | Diggory Hardy <diggory.hardy@gmail.com> |
---|---|
date | Fri, 27 Jun 2008 18:35:33 +0100 |
parents | 7cab2af4ba21 |
children | 56c0ddd90193 |
line wrap: on
line source
/* LICENSE BLOCK Part of mde: a Modular D game-oriented Engine Copyright © 2007-2008 Diggory Hardy This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see <http://www.gnu.org/licenses/>. */ /** Handling for all events from SDL_PollEvent. * * Handles some events, including a quit-request and window resizing, and passes the rest on to the * input system. */ module mde.events; import imde = mde.imde; import sdl = mde.setup.sdl; // resizeWindow import mde.input.Input; import derelict.sdl.events; import tango.time.Time; import tango.util.log.Log : Log, Logger; import tango.io.Stdout; private Logger logger; static this() { logger = Log.getLogger ("mde.events"); } void pollEvents (TimeSpan) { SDL_Event event; while (SDL_PollEvent (&event)) { switch (event.type) { case SDL_QUIT: logger.info ("Quit requested"); imde.run = false; break; case SDL_VIDEORESIZE: sdl.resizeWindow (event.resize.w, event.resize.h); imde.mainSchedule.request(imde.SCHEDULE.DRAW); break; case SDL_ACTIVEEVENT: case SDL_VIDEOEXPOSE: imde.mainSchedule.request(imde.SCHEDULE.DRAW); break; default: try { if (!imde.input (event)) debug Stdout ("Unrecognised event with code ")(event.type).newline; } catch (Exception e) { logger.error ("Caught input exception; event will be ignored. Exception was:"); logger.error (e.msg); } } } }