summaryrefslogtreecommitdiff
path: root/include
diff options
context:
space:
mode:
Diffstat (limited to 'include')
-rw-r--r--include/Exceptions.h11
-rw-r--r--include/Handle.h4
-rw-r--r--include/Input.h2
-rw-r--r--include/Makefile.am2
-rw-r--r--include/Output.h2
-rw-r--r--include/Task.h7
-rw-r--r--include/TaskMan.h22
7 files changed, 37 insertions, 13 deletions
diff --git a/include/Exceptions.h b/include/Exceptions.h
index 8c37342..56460a6 100644
--- a/include/Exceptions.h
+++ b/include/Exceptions.h
@@ -34,10 +34,10 @@
class MemoryException;
-char * xstrdup(const char *) throw (MemoryException);
-void * xmalloc(ssize_t) throw (MemoryException);
+char * xstrdup(const char *) throw (GeneralException);
+void * xmalloc(ssize_t) throw (GeneralException);
void xfree(void *&);
-void * xrealloc(void *, size_t) throw (MemoryException);
+void * xrealloc(void *, size_t) throw (GeneralException);
// On prédéfinit la classe String, pour éviter
// les deadlocks de compilation...
@@ -110,6 +110,11 @@ class IOAgain : public IOGeneral {
IOAgain();
};
+class TaskSwitch : public GeneralException {
+ public:
+ TaskSwitch();
+};
+
#else
#error This only works with a C++ compiler
#endif
diff --git a/include/Handle.h b/include/Handle.h
index 2554892..6d44a48 100644
--- a/include/Handle.h
+++ b/include/Handle.h
@@ -28,8 +28,8 @@ class Handle : public Base {
public:
Handle(const Handle &);
virtual ~Handle();
- virtual ssize_t read(void *buf, size_t count) throw (IOGeneral);
- virtual ssize_t write(const void *buf, size_t count) throw (IOGeneral);
+ virtual ssize_t read(void *buf, size_t count) throw (GeneralException);
+ virtual ssize_t write(const void *buf, size_t count) throw (GeneralException);
bool IsClosed(void);
bool IsNonBlock(void);
void SetNonBlock(void);
diff --git a/include/Input.h b/include/Input.h
index 81a48d8..1beb1b5 100644
--- a/include/Input.h
+++ b/include/Input.h
@@ -11,7 +11,7 @@
class Input : public Handle {
public:
- Input(String = "") throw (IOGeneral);
+ Input(String = "") throw (GeneralException);
virtual ~Input() {}
virtual bool CanWrite();
virtual bool CanRead();
diff --git a/include/Makefile.am b/include/Makefile.am
index 156307a..9546421 100644
--- a/include/Makefile.am
+++ b/include/Makefile.am
@@ -1,4 +1,4 @@
include_HEADERS = \
Exceptions.h Handle.h String.h Output.h Socket.h HttpServ.h Variables.h Menu.h \
Action.h Message.h Form.h Confirm.h Table.h IRC.h Task.h Buffer.h General.h \
-CopyJob.h ReadJob.h Regex.h
+CopyJob.h ReadJob.h Regex.h TaskMan.h
diff --git a/include/Output.h b/include/Output.h
index 6c944ab..98af0ac 100644
--- a/include/Output.h
+++ b/include/Output.h
@@ -11,7 +11,7 @@
class Output : public Handle {
public:
- Output(String = "", int trunc = 1) throw (IOGeneral);
+ Output(String = "", int trunc = 1) throw (GeneralException);
virtual ~Output() {}
virtual bool CanWrite();
virtual bool CanRead();
diff --git a/include/Task.h b/include/Task.h
index c67a59c..f2fe722 100644
--- a/include/Task.h
+++ b/include/Task.h
@@ -4,11 +4,8 @@
#include "Exceptions.h"
-#define TASK_ON_HOLD 1
-#define TASK_DONE 2
-#define TASK_WAITING_HANDLE 4
-#define TASK_WAITING_TIMEOUT 8
-#define TASK_WAITING_TASK 16
+#define TASK_ON_HOLD 0
+#define TASK_DONE 1
class Task : public Base {
public:
diff --git a/include/TaskMan.h b/include/TaskMan.h
new file mode 100644
index 0000000..fe0d565
--- /dev/null
+++ b/include/TaskMan.h
@@ -0,0 +1,22 @@
+#ifndef __TASKMAN_H__
+#define __TASKMAN_H__
+#ifdef __cplusplus
+
+#include <Task,h>
+#include <vector.h>
+
+catch TaskMan : public Base {
+ public:
+ TaskMan();
+ ~TaskMan();
+ int AddTask(const Task &);
+ void MainLoop(void);
+ private:
+ vector<Task> TaskList;
+ static int Inited;
+};
+
+#else
+#error This only works with a C++ compiler
+#endif
+#endif