X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fcore%2Fapplication.h;h=08393b724b486077452e9ffb940bd9822fc6578c;hb=79482ba7aea1b79c7a310c940cc0292532ef3bcb;hp=305fbfe34661967a3d8dbeca46ed30f2f9c1596f;hpb=1876f64c4ec1bcba8de57b8b5f63e250187b4ad1;p=libs%2Fcore.git diff --git a/source/core/application.h b/source/core/application.h index 305fbfe..08393b7 100644 --- a/source/core/application.h +++ b/source/core/application.h @@ -1,18 +1,10 @@ -/* $Id$ - -This file is part of libmspcore -Copyright © 2006-2008, 2011 Mikko Rasa, Mikkosoft Productions -Distributed under the LGPL -*/ - #ifndef MSP_CORE_APPLICATION_H_ #define MSP_CORE_APPLICATION_H_ namespace Msp { /** -Base class for applications. Inherit the main class from this and add a static -member of type RegApp. +Base class for applications. See also RegisteredApplication. */ class Application { @@ -25,7 +17,6 @@ protected: virtual ~Starter() { } virtual Application *create_app(int, char **) = 0; - virtual void usage(const char *, const char *, bool) = 0; }; bool done; @@ -36,13 +27,14 @@ private: 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: @@ -55,9 +47,11 @@ private: static void sighandler_(int); }; - Application(const Application &); - Application &operator=(const Application &); +/** +Registers the class to be used for program startup. The main application class +should be derived from this. +*/ template class RegisteredApplication: public Application { @@ -66,7 +60,6 @@ private: { 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); } }; static Starter starter_;