X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fcore%2Fapplication.h;h=4ae8c5614250819ec6aa28ed83c7cc6461f7ee69;hb=ab956fd92f2110197c8e035b12dafa30a18b8ae1;hp=38df732f1a5779782566d249b701a19ca99011a2;hpb=fcd7272c28b6da5a68d41e5aac7be1dfd2eeab78;p=libs%2Fcore.git diff --git a/source/core/application.h b/source/core/application.h index 38df732..4ae8c56 100644 --- a/source/core/application.h +++ b/source/core/application.h @@ -17,39 +17,32 @@ member of type RegApp. class Application { protected: - class RegBase + class Starter { - public: - virtual Application *create_app(int, char **)=0; - virtual void usage(const char *, const char *, bool)=0; - virtual ~RegBase() { } protected: - RegBase(); - }; - - template - class RegApp: public RegBase - { + Starter(); public: - Application *create_app(int argc, char **argv) { return new T(argc, argv); } - void usage(const char *r, const char *a, bool b) { T::usage(r, a, b); } + virtual ~Starter() { } + + virtual Application *create_app(int, char **) = 0; }; bool done; int exit_code; private: - static RegBase *reg_app_; + static Starter *starter_; static Application *app_; static void *data_; + Application(const Application &); + Application &operator=(const Application &); 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: @@ -60,11 +53,29 @@ protected: virtual void sighandler(int) { } private: static void sighandler_(int); +}; - Application(const Application &); - Application &operator=(const Application &); + +template +class RegisteredApplication: public Application +{ +private: + class Starter: public Application::Starter + { + public: + Application *create_app(int argc, char **argv) { return new T(argc, argv); } + }; + + static Starter starter_; + +protected: + // Force the starter into existence + RegisteredApplication() { (void)starter_; } }; +template +typename RegisteredApplication::Starter RegisteredApplication::starter_; + } // namespace Msp #endif