X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fcore%2Fapplication.h;h=d3b992e17a019321c31579cfb6804178a4d2d2ac;hb=20e1beb546c26eae3b1a61ab2051108a7dca221f;hp=fa0c9c41bcf42a7923237b21cdcc410233599226;hpb=fe77fc6b869a71bf94d501a0762579f4ddbc5094;p=libs%2Fcore.git diff --git a/source/core/application.h b/source/core/application.h index fa0c9c4..d3b992e 100644 --- a/source/core/application.h +++ b/source/core/application.h @@ -1,10 +1,11 @@ -/* +/* $Id$ + This file is part of libmspcore Copyright © 2006 Mikko Rasa, Mikkosoft Productions Distributed under the LGPL */ -#ifndef MSP_FRAMEWORK_APPLICATION_H_ -#define MSP_FRAMEWORK_APPLICATION_H_ +#ifndef MSP_CORE_APPLICATION_H_ +#define MSP_CORE_APPLICATION_H_ #include "semaphore.h" @@ -19,17 +20,19 @@ class Application public: virtual ~Application() { } - static int run(int, char **); + static int run(int, char **, void * =0); static void usage(const char *, const char *, bool); + static void *get_data() { return data_; } protected: enum LoopMode { NONE, /// No main loop - main() will just return SLEEP, /// Only sleep in the main loop - useful for servers TICK_SLEEP, /// Call tick every iteration, with a short sleep in between - TICK_YIELD /// Call tick every iteration, with sched_yield in between + TICK_YIELD, /// Call tick every iteration, with sched_yield in between + TICK_BUSY /// Call tick every iteration }; - + class RegBase { public: @@ -68,6 +71,7 @@ private: static RegBase *reg_app_; static Application *app_; + static void *data_; static void sighandler_(int); static void sigalrm_(int) { }