#include <Moof/Dispatcher.hh>
#include <Moof/Exception.hh>
#include <Moof/Log.hh>
+#include <Moof/ModalDialog.hh>
#include <Moof/OpenGL.hh>
#include <Moof/Resource.hh>
#include <Moof/Transition.hh>
}
-void MainLayer::pushed(Mf::Engine& e)
+void MainLayer::pushed(Mf::Engine& engine)
{
- engine = &e;
+ mEngine = &engine;
//Mf::Scalar coeff[] = {0.0, 1.0};
//Mf::Lerp interp(coeff, 0.25);
//Mf::Transition<Mf::Lerp>::alloc(gameLayer, Mf::LayerP(), interp);
//engine->push(transition);
//engine->push(GameLayer::alloc());
- engine->push(TitleLayer::alloc());
+ mEngine->push(TitleLayer::alloc());
}
}
else if (event.key.keysym.sym == SDLK_f)
{
- engine->getVideo().toggleFull();
+ mEngine->getVideo().toggleFull();
}
else if (event.key.keysym.sym == SDLK_l)
{
- Mf::Video& video = engine->getVideo();
+ Mf::Video& video = mEngine->getVideo();
video.toggleCursorGrab();
video.toggleCursorVisible();
}
else if (event.key.keysym.sym == SDLK_y)
{
- engine->push(GameLayer::alloc());
+ mEngine->push(GameLayer::alloc());
}
break;
// the operating system will take care of cleaning up
exit(0);
#else
- engine->clear();
+ mEngine->clear();
#endif
}
void printUsage()
{
- std::cout << "Usage: "PACKAGE" [-h|--help] [-i|--info] [OPTION=VALUE]..." << std::endl
+ std::cout << "Usage: "PACKAGE" [-h|--help] [-i|--info] [OPTION=VALUE]..."
+ << std::endl
<< "The alien-smashing action game." << std::endl
<< std::endl
<< "Options:" << std::endl
std::cout << " Executable: " << argv[0] << std::endl
<< " Version: "VERSION << std::endl
-#ifdef __DATE__
+#if defined(__DATE__) && defined(__TIME__)
<< " Built: "__DATE__" "__TIME__ << std::endl
#endif
<< " Compiler: "COMPILER_STRING << std::endl
<< "-"
#endif
<< "double-precision "
+#ifndef USE_GTK
+ << "-"
+#endif
+ << "gtk "
#ifndef PROFILING_ENABLED
<< "-"
#endif
<< "profile "
+#ifndef USE_QT4
+ << "-"
+#endif
+ << "qt4 "
#ifndef USE_THREADS
<< "-"
#endif
}
-
int main(int argc, char* argv[])
{
if (argc > 1)
Mf::Resource::addSearchPath(YOINK_DATADIR);
- std::string iconFile = Mf::Resource::getPath("yoink.png");
+ std::string iconFile = Mf::Resource::getPath(PACKAGE".png");
// Build the list of config files to search for, in this order:
configFiles += configFile;
}
-
try
{
Mf::Engine app(argc, argv, PACKAGE_STRING, iconFile, configFiles);
app.run();
}
- catch (Mf::Exception e)
+ catch (const Mf::Exception& e)
{
- Mf::logError("unhandled exception: <<%s>>", e.what());
- Mf::logInfo("it's time to crash now :-(");
- throw e;
+ Mf::logError("unhandled exception (code %d): \"%s\"",
+ e.code(), e.what());
+
+ Mf::ModalDialog dialog;
+ dialog.title = PACKAGE_STRING;
+ dialog.text1 = "Unhandled Exception";
+ dialog.text2 = e.what();
+ dialog.type = Mf::ModalDialog::CRITICAL;
+ dialog.run();
+
+ return 1;
}
return 0;