summaryrefslogtreecommitdiff
path: root/include
diff options
context:
space:
mode:
Diffstat (limited to 'include')
-rw-r--r--include/Task.h42
-rw-r--r--include/TaskMan.h10
2 files changed, 33 insertions, 19 deletions
diff --git a/include/Task.h b/include/Task.h
index d976124..32cbf85 100644
--- a/include/Task.h
+++ b/include/Task.h
@@ -29,6 +29,7 @@
#include <vector>
#include <Exceptions.h>
#include <Handle.h>
+#include <TaskMan.h>
#undef E_HANDLE
#undef Yield
@@ -41,42 +42,47 @@ class Task : public Base {
EVT_PROCESS,
EVT_TIMEOUT,
EVT_TASK,
+ EVT_IDLE,
};
enum {
TASK_ON_HOLD = 0,
TASK_DONE,
TASK_BURST,
+ TASK_IDLE,
+ TASK_IDLE_REST,
};
enum {
W4_STICKY = 1,
W4_READING = 2,
W4_WRITING = 4,
};
- Task();
+ Task() : current(0), state(TASK_ON_HOLD), stopped(false), suspended(false), yielded(false), wbta(0), wta(0), BurstHandle(0) { TaskMan::AddTask(this); }
virtual ~Task();
- virtual String GetName();
+ virtual String GetName() { return "Unknow Task"; }
int Run();
int DryRun();
- int GetState();
+ int GetState() { return state; }
void Suspend(int = -1) throw (GeneralException);
- void WaitFor(Task *);
- void WaitFor(Handle *, int = 0);
- void WaitFor(pid_t);
- void WaitFor(const timeval &, int = 0);
- void Yield();
- bool Yielded();
- void Unyield();
- Task * WaitedBy();
- void SetBurst();
- void Stop();
- void Restart();
- bool IsStopped();
- void RemoveFromWatches();
- void RemoveTimeout();
+ void WaitFor(Task * t) { t->wbta = this; wta = t; }
+ void WaitFor(Handle * h, int flags = 0) { h->SetNonBlock(); TaskMan::WaitFor(h, this, flags); }
+ void WaitFor(pid_t p) { TaskMan::WaitFor(p, this); }
+ void WaitFor(const timeval & t, int flags = 0) { TaskMan::WaitFor(t, this, flags); }
+ void Yield() { yielded = true; Suspend(TASK_ON_HOLD); }
+ bool Yielded() { return yielded; }
+ void Unyield() { yielded = false; SetBurst(); }
+ Task * WaitedBy() { return wbta; }
+ void SetBurst() { state = TASK_BURST; }
+ void SetIdle() { state = TASK_IDLE; }
+ void IdleRest() { state = TASK_IDLE_REST; }
+ void Stop() { stopped = true; }
+ void Restart() { stopped = false; }
+ bool IsStopped() { return stopped; }
+ void RemoveFromWatches() { wbta = 0; }
+ void RemoveTimeout() { TaskMan::RemoveTimeout(this); }
Handle * BurstHandle;
protected:
- virtual int Do() throw (GeneralException);
+ virtual int Do() throw (GeneralException) { return TASK_ON_HOLD; }
int current;
private:
diff --git a/include/TaskMan.h b/include/TaskMan.h
index 59363f8..2bc7495 100644
--- a/include/TaskMan.h
+++ b/include/TaskMan.h
@@ -25,8 +25,11 @@ typedef int sigset_t;
#endif
#include <signal.h>
-#include <Task.h>
+#include <Atomic.h>
#include <vector>
+#include <Handle.h>
+
+class Task;
class TaskMan : public Base {
public:
@@ -80,6 +83,8 @@ class TaskMan : public Base {
Task * T;
};
typedef std::vector<Task *> TaskList_t;
+
+ static void ProcessNewTasks();
static TaskList_t TaskList;
static TaskList_t Zombies;
@@ -96,6 +101,9 @@ class TaskMan : public Base {
static sigset_t sigchildset;
static int got_sigchild;
static bool CheckDead(Task *);
+ static Atomic::Queue<Task> new_tasks;
};
+#include <Task.h>
+
#endif