X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Finternaltask.h;h=c927b0ba9de5f0261ceb07b54860a5a89a3b044a;hb=bc85cc286c8a3f1055f1979a7ff8697cf1b61912;hp=ea25ba89eca0816751d8f13687b5e4aa5afeefd8;hpb=338eefb513953ae55e8e3614c009c242ba8ad74e;p=builder.git diff --git a/source/internaltask.h b/source/internaltask.h index ea25ba8..c927b0b 100644 --- a/source/internaltask.h +++ b/source/internaltask.h @@ -4,13 +4,20 @@ #include #include "task.h" +/** +Runs a worker thread. Tools should derive a thread class from +InternalTask::Worker. The worker thread must set its status to either SUCCESS +or ERROR before terminating. +*/ class InternalTask: public Task { public: class Worker: public Msp::Thread { + friend class InternalTask; + protected: - Status status; + volatile Status status; Worker(); @@ -25,7 +32,10 @@ public: InternalTask(Worker *); ~InternalTask(); + virtual std::string get_command() const { return ""; } + virtual void start(); virtual Status check(); + virtual Status wait(); }; #endif