Mercurial > projects > mde
view mde/events.d @ 21:a60cbb7359dd
Window settings now come from options, and may use OpenGL (enabled/disabled at compile time).
committer: Diggory Hardy <diggory.hardy@gmail.com>
author | Diggory Hardy <diggory.hardy@gmail.com> |
---|---|
date | Mon, 24 Mar 2008 17:53:28 +0000 |
parents | 838577503598 |
children | 249eb6620685 |
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, version 2, as published by the Free Software Foundation. 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, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. */ /// Handles all events from SDL_PollEvent. module mde.events; import mde.scheduler.InitStage; import mde.scheduler.runTime; import global = mde.global; import mde.input.input; import mde.input.exception; import derelict.sdl.events; import tango.util.log.Log : Log, Logger; private Logger logger; static this() { logger = Log.getLogger ("mde.events"); init2.addFunc (&initInput); } void initInput () { // init2 func logger.trace ("init2: initInput() started"); try { global.input = new Input(); global.input.loadConfig (); // (may also create instance) Scheduler.perFrame (&pollEvents); } catch (Exception e) { setInitFailure (); // must clean up properly } logger.trace ("init2: initInput() finished"); } void pollEvents (double) { SDL_Event event; while (SDL_PollEvent (&event)) { switch (event.type) { case SDL_QUIT: logger.info ("Quit requested"); global.run = false; break; default: try { global.input (event); } catch (InputClassException e) { logger.warn ("Caught input exception; event will be ignored. Exception was:"); logger.warn (e.msg); } } } }