Added a Refrenced::getGlobalReferencedMutex, and OpenThreads::ScopedPointerLock() and use of this in add/removeParent() codes
to avoid threading problems when using atomic ref counting.
This commit is contained in:
@@ -281,32 +281,17 @@ void Drawable::computeDataVariance()
|
||||
|
||||
void Drawable::addParent(osg::Node* node)
|
||||
{
|
||||
if (getRefMutex())
|
||||
{
|
||||
OpenThreads::ScopedLock<OpenThreads::Mutex> lock(*getRefMutex());
|
||||
OpenThreads::ScopedPointerLock<OpenThreads::Mutex> lock(getRefMutex());
|
||||
|
||||
_parents.push_back(node);
|
||||
}
|
||||
else
|
||||
{
|
||||
_parents.push_back(node);
|
||||
}
|
||||
_parents.push_back(node);
|
||||
}
|
||||
|
||||
void Drawable::removeParent(osg::Node* node)
|
||||
{
|
||||
if (getRefMutex())
|
||||
{
|
||||
OpenThreads::ScopedLock<OpenThreads::Mutex> lock(*getRefMutex());
|
||||
OpenThreads::ScopedPointerLock<OpenThreads::Mutex> lock(getRefMutex());
|
||||
|
||||
ParentList::iterator pitr = std::find(_parents.begin(),_parents.end(),node);
|
||||
if (pitr!=_parents.end()) _parents.erase(pitr);
|
||||
}
|
||||
else
|
||||
{
|
||||
ParentList::iterator pitr = std::find(_parents.begin(),_parents.end(),node);
|
||||
if (pitr!=_parents.end()) _parents.erase(pitr);
|
||||
}
|
||||
ParentList::iterator pitr = std::find(_parents.begin(),_parents.end(),node);
|
||||
if (pitr!=_parents.end()) _parents.erase(pitr);
|
||||
}
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user