X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fcore%2Fapplication.h;h=ca51bbc0a5f59009227fb3dffc3e54f4a86e9d9a;hb=cfc8e0b7b15ea505bd6a6a9599cbc5ce1e316963;hp=bd433aafcc3fb16dfd0e0d1bc51c435f6bf5adab;hpb=ce8b99f8d48b7783fd97f3959198f9c54cebec72;p=libs%2Fcore.git diff --git a/source/core/application.h b/source/core/application.h index bd433aa..ca51bbc 100644 --- a/source/core/application.h +++ b/source/core/application.h @@ -17,16 +17,11 @@ member of type RegApp. */ class Application { -public: - virtual ~Application() { } - - static int run(int, char **); - static void usage(const char *, const char *, bool); protected: enum LoopMode { NONE, /// No main loop - main() will just return - SLEEP, /// Only sleep in the main loop - useful for servers + SLEEP, /// Only sleep in the main loop - useful for threaded 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_BUSY /// Call tick every iteration @@ -51,9 +46,26 @@ protected: }; bool done; - int exit_code; + int exit_code; + +private: + LoopMode loop_mode_; + Semaphore sleep_sem_; + + static RegBase *reg_app_; + static Application *app_; + static void *data_; +protected: Application(); +public: + virtual ~Application() { } + + static int run(int, char **, void * =0); + static void usage(const char *, const char *, bool); + static void *get_data() { return data_; } + +protected: virtual int main(); void catch_signal(int); void set_loop_mode(LoopMode); @@ -62,17 +74,10 @@ protected: virtual void tick() { } virtual void sighandler(int) { } private: - LoopMode loop_mode_; - Semaphore sleep_sem_; + static void sighandler_(int); Application(const Application &); Application &operator=(const Application &); - - static RegBase *reg_app_; - static Application *app_; - - static void sighandler_(int); - static void sigalrm_(int) { } }; } // namespace Msp