forked from Mirrorlandia_minetest/minetest
Fix emerge thread not cleaning up emerge queue on shutdown
This commit is contained in:
parent
2b8ed9e80c
commit
ef140eb7b0
@ -580,6 +580,23 @@ void *EmergeThread::Thread()
|
|||||||
m_server->setAsyncFatalError(err.str());
|
m_server->setAsyncFatalError(err.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
JMutexAutoLock queuelock(emerge->queuemutex);
|
||||||
|
while (!blockqueue.empty())
|
||||||
|
{
|
||||||
|
v3s16 p = blockqueue.front();
|
||||||
|
blockqueue.pop();
|
||||||
|
|
||||||
|
std::map<v3s16, BlockEmergeData *>::iterator iter;
|
||||||
|
iter = emerge->blocks_enqueued.find(p);
|
||||||
|
if (iter == emerge->blocks_enqueued.end())
|
||||||
|
continue; //uh oh, queue and map out of sync!!
|
||||||
|
|
||||||
|
BlockEmergeData *bedata = iter->second;
|
||||||
|
delete bedata;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
END_DEBUG_EXCEPTION_HANDLER(errorstream)
|
END_DEBUG_EXCEPTION_HANDLER(errorstream)
|
||||||
log_deregister_thread();
|
log_deregister_thread();
|
||||||
return NULL;
|
return NULL;
|
||||||
|
Loading…
Reference in New Issue
Block a user