X-Git-Url: http://git.tdb.fi/?p=libs%2Fcore.git;a=blobdiff_plain;f=source%2Fcore%2Fapplication.h;h=d0985be900fb493714760ab07335d06faaa87298;hp=af18cea664b35eca77cc2148fd4db6815f5fadb6;hb=55a73ee19194aec4179955aed78798c120fb99af;hpb=dd997d45dd774b1d6734a19c6eb6efdd6be14234 diff --git a/source/core/application.h b/source/core/application.h index af18cea..d0985be 100644 --- a/source/core/application.h +++ b/source/core/application.h @@ -2,6 +2,7 @@ #define MSP_CORE_APPLICATION_H_ #include +#include namespace Msp { @@ -27,12 +28,14 @@ protected: private: static Starter *starter_; static Application *app_; + static const char *argv0_; + static std::string name_; static void *data_; Application(const Application &); Application &operator=(const Application &); protected: - Application(); + Application(const std::string & = std::string()); public: virtual ~Application() { } @@ -44,7 +47,16 @@ public: by the library normally does it automatically at program startup. */ static int run(int, char **, void * =0, void (*)(void *) = 0); + /** Sets application startup info, including argv[0] value and platform- + specific data. + + This function can only be called once, and is normally called by + Application::run(). */ + static void set_startup_info(const char *, void *); + static void *get_data() { return data_; } + static const char *get_argv0() { return argv0_; } + static const std::string &get_name() { return name_; } protected: /** Default main loop. Calls tick() repeatedly until exit() is called. A @@ -86,8 +98,9 @@ private: static Starter starter_; protected: - // Force the starter into existence - RegisteredApplication() { (void)starter_; } + RegisteredApplication(const std::string &n = std::string()): + Application(n) + { (void)starter_; } // Force the starter into existence }; template