X-Git-Url: http://git.tdb.fi/?p=libs%2Fcore.git;a=blobdiff_plain;f=source%2Fcore%2Fapplication.h;h=1384085ef58c3b134b9aa0abecbc68fcbd9d7e9e;hp=b51ac3c446e8e87028623ea0db5751871cacc874;hb=b2333b53a0434eb6a131000c0b9bf06e4f603bd6;hpb=d5dd704b2576f878809e87dbb8ff8591b9bdbce4 diff --git a/source/core/application.h b/source/core/application.h index b51ac3c..1384085 100644 --- a/source/core/application.h +++ b/source/core/application.h @@ -1,18 +1,12 @@ -/* $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_ +#include + 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 +19,6 @@ protected: virtual ~Starter() { } virtual Application *create_app(int, char **) = 0; - virtual void usage(const char *, const char *, bool) = 0; }; bool done; @@ -43,21 +36,45 @@ protected: public: virtual ~Application() { } + /** Constructs an instance of the registered application class and runs it. + If the application throws a usage_error, a help message is printed. The + GetOpt class will throw such exceptions automatically in error conditions. + + This function can only be called once. The global main() function provided + by the library normally does it automatically at program startup. */ static int run(int, char **, void * =0); - static void usage(const char *, const char *, bool); + static void *get_data() { return data_; } protected: + /** Default main loop. Calls tick() repeatedly until exit() is called. A + custom main loop should monitor the done member variable and return + exit_code. */ virtual int main(); + + /** Sets the specified signal to be delivered to the sighandler member + function. */ void catch_signal(int); + + /** Causes the application to exit gracefully with the given exit code. */ void exit(int); + virtual void tick() { } virtual void sighandler(int) { } + private: + /** Static wrapper function to call a member function of the Application + instance. */ static void sighandler_(int); + + static void display_exception(const std::exception &); }; +/** +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 +83,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_;