Mercurial > projects > mde
view mde/events.d @ 61:7cab2af4ba21
A little bit of progress on the content handling system (relevent code is likely to be revised).
Also some changes to debug statements, in particular a new drawGlyphCache debug version.
author | Diggory Hardy <diggory.hardy@gmail.com> |
---|---|
date | Wed, 25 Jun 2008 17:25:48 +0100 |
parents | 57d000574d75 |
children | 66d555da083e |
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/>. */ /// Handles all events from SDL_PollEvent. module mde.events; import imde = mde.imde; import sdl = mde.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); } } } }