]> git.tdb.fi Git - builder.git/blobdiff - source/internaltask.cpp
Refactor InternalTask to take a functor
[builder.git] / source / internaltask.cpp
index c117bad897365f9e4159f7c58b9f9b764f6ae13c..fc929ce02b2f843c2bd6de87331bbe081f11017c 100644 (file)
@@ -1,35 +1,36 @@
 #include "internaltask.h"
 
-InternalTask::InternalTask(Worker *w):
-       worker(w)
-{ }
-
 InternalTask::~InternalTask()
 {
-       worker->join();
-       delete worker;
+       worker.join();
 }
 
 void InternalTask::start()
 {
-       worker->launch();
+       prepare();
+       worker.launch();
 }
 
 Task::Status InternalTask::check()
 {
-       if(worker->get_status()!=RUNNING)
-               signal_finished.emit(worker->get_status()==SUCCESS);
-       return worker->get_status();
+       Status result = worker.get_status();
+       if(result!=RUNNING)
+               signal_finished.emit(result==SUCCESS);
+       return result;
 }
 
 Task::Status InternalTask::wait()
 {
        Status result;
-       while((result = worker->get_status())==RUNNING) ;
+       while((result = check())==RUNNING) ;
        return result;
 }
 
 
-InternalTask::Worker::Worker():
-       status(RUNNING)
-{ }
+void InternalTask::Worker::main()
+{
+       if(func())
+               status = Task::SUCCESS;
+       else
+               status = Task::ERROR;
+}