]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/threadengines/threadengine_pthread.cpp
Add new cross-module event system
[user/henk/code/inspircd.git] / src / threadengines / threadengine_pthread.cpp
index 27641f0ac3f492ce619e901372eebbbadd2a0458..fcb4db444b0b63b8e776721d838b29ed839f099c 100644 (file)
 #include "inspircd.h"
 #include "threadengines/threadengine_pthread.h"
 #include <pthread.h>
-#include <signal.h>
 #include <fcntl.h>
 
-ThreadEngine::ThreadEngine()
-{
-}
-
 static void* entry_point(void* parameter)
 {
        /* Recommended by nenolod, signal safety on a per-thread basis */
@@ -44,25 +39,14 @@ static void* entry_point(void* parameter)
 
 void ThreadEngine::Start(Thread* thread)
 {
-       ThreadData* data = new ThreadData;
-       thread->state = data;
-
-       if (pthread_create(&data->pthread_id, NULL, entry_point, thread) != 0)
-       {
-               thread->state = NULL;
-               delete data;
+       if (pthread_create(&thread->state.pthread_id, NULL, entry_point, thread) != 0)
                throw CoreException("Unable to create new thread: " + std::string(strerror(errno)));
-       }
-}
-
-ThreadEngine::~ThreadEngine()
-{
 }
 
-void ThreadData::FreeThread(Thread* thread)
+void ThreadEngine::Stop(Thread* thread)
 {
        thread->SetExitFlag();
-       pthread_join(pthread_id, NULL);
+       pthread_join(thread->state.pthread_id, NULL);
 }
 
 #ifdef HAS_EVENTFD
@@ -80,8 +64,7 @@ class ThreadSignalSocket : public EventHandler
 
        ~ThreadSignalSocket()
        {
-               SocketEngine::DelFd(this);
-               SocketEngine::Close(GetFd());
+               SocketEngine::Close(this);
        }
 
        void Notify()
@@ -130,8 +113,7 @@ class ThreadSignalSocket : public EventHandler
        ~ThreadSignalSocket()
        {
                close(send_fd);
-               SocketEngine::DelFd(this);
-               SocketEngine::Close(GetFd());
+               SocketEngine::Close(this);
        }
 
        void Notify()