Skip to content

Commit

Permalink
Small shutdown crash bug fixed
Browse files Browse the repository at this point in the history
git-svn-id: https://opentibia.svn.sourceforge.net/svnroot/opentibia/otserv/trunk@6269 c77455bc-2124-0410-8220-ac9e7aafbb94
  • Loading branch information
iryont committed Apr 18, 2012
1 parent 71af2fd commit 50ddcce
Show file tree
Hide file tree
Showing 5 changed files with 17 additions and 2 deletions.
2 changes: 2 additions & 0 deletions otserv.cpp
Expand Up @@ -256,6 +256,8 @@ int main(int argc, char** argv)
std::cout << "[done]" << std::endl;
std::cout << ":: Server Running..." << std::endl;
servicer.run();
g_scheduler.join();
g_dispatcher.join();
}
else{
ErrorMessage("No services running. Server is not online.");
Expand Down
6 changes: 5 additions & 1 deletion scheduler.cpp
Expand Up @@ -32,7 +32,7 @@ Scheduler::Scheduler()
void Scheduler::start()
{
m_threadState = STATE_RUNNING;
boost::thread(boost::bind(&Scheduler::schedulerThread, (void*)this));
m_thread = boost::thread(boost::bind(&Scheduler::schedulerThread, (void*)this));
}

void Scheduler::schedulerThread(void* p)
Expand Down Expand Up @@ -205,3 +205,7 @@ void Scheduler::shutdown()
m_eventLock.unlock();
}

void Scheduler::join()
{
m_thread.join();
}
2 changes: 2 additions & 0 deletions scheduler.h
Expand Up @@ -87,6 +87,7 @@ class Scheduler
void start();
void stop();
void shutdown();
void join();

enum SchedulerState{
STATE_RUNNING,
Expand All @@ -97,6 +98,7 @@ class Scheduler
protected:
static void schedulerThread(void* p);

boost::thread m_thread;
boost::mutex m_eventLock;
boost::condition_variable m_eventSignal;

Expand Down
7 changes: 6 additions & 1 deletion tasks.cpp
Expand Up @@ -35,7 +35,7 @@ Dispatcher::Dispatcher()
void Dispatcher::start()
{
m_threadState = STATE_RUNNING;
boost::thread(boost::bind(&Dispatcher::dispatcherThread, (void*)this));
m_thread = boost::thread(boost::bind(&Dispatcher::dispatcherThread, (void*)this));
}

void Dispatcher::dispatcherThread(void* p)
Expand Down Expand Up @@ -174,3 +174,8 @@ void Dispatcher::shutdown()
std::cout << "Shutdown Dispatcher" << std::endl;
#endif
}

void Dispatcher::join()
{
m_thread.join();
}
2 changes: 2 additions & 0 deletions tasks.h
Expand Up @@ -84,6 +84,7 @@ class Dispatcher{
void start();
void stop();
void shutdown();
void join();

enum DispatcherState{
STATE_RUNNING,
Expand All @@ -97,6 +98,7 @@ class Dispatcher{

void flush();

boost::thread m_thread;
boost::mutex m_taskLock;
boost::condition_variable m_taskSignal;

Expand Down

0 comments on commit 50ddcce

Please sign in to comment.