Race condition fix

This commit is contained in:
scrawl 2015-06-10 19:02:33 +02:00
parent 35b2d91fb3
commit 9c86d4f8bc
2 changed files with 4 additions and 3 deletions

View file

@ -25,6 +25,7 @@ void WorkTicket::signalDone()
WorkItem::WorkItem()
: mTicket(new WorkTicket)
{
mTicket->setThreadSafeRefUnref(true);
}
WorkItem::~WorkItem()
@ -73,9 +74,9 @@ WorkQueue::~WorkQueue()
}
}
WorkTicket* WorkQueue::addWorkItem(WorkItem *item)
osg::ref_ptr<WorkTicket> WorkQueue::addWorkItem(WorkItem *item)
{
WorkTicket* ticket = item->getTicket().get();
osg::ref_ptr<WorkTicket> ticket = item->getTicket();
OpenThreads::ScopedLock<OpenThreads::Mutex> lock(mMutex);
mQueue.push(item);
mCondition.signal();