mirror of
https://github.com/OpenMW/openmw.git
synced 2025-01-21 06:23:53 +00:00
fixed object removal via setting state to delete
This commit is contained in:
parent
c1f0aa7260
commit
790367b980
2 changed files with 31 additions and 13 deletions
|
@ -22,11 +22,18 @@ bool CSVRender::Cell::removeObject (const std::string& id)
|
|||
if (iter==mObjects.end())
|
||||
return false;
|
||||
|
||||
delete iter->second;
|
||||
mObjects.erase (iter);
|
||||
removeObject (iter);
|
||||
return true;
|
||||
}
|
||||
|
||||
std::map<std::string, CSVRender::Object *>::iterator CSVRender::Cell::removeObject (
|
||||
std::map<std::string, Object *>::iterator iter)
|
||||
{
|
||||
delete iter->second;
|
||||
mObjects.erase (iter++);
|
||||
return iter;
|
||||
}
|
||||
|
||||
bool CSVRender::Cell::addObjects (int start, int end)
|
||||
{
|
||||
bool modified = false;
|
||||
|
@ -161,8 +168,8 @@ bool CSVRender::Cell::referenceDataChanged (const QModelIndex& topLeft,
|
|||
// perform update and remove where needed
|
||||
bool modified = false;
|
||||
|
||||
for (std::map<std::string, Object *>::iterator iter (mObjects.begin());
|
||||
iter!=mObjects.end(); ++iter)
|
||||
std::map<std::string, Object *>::iterator iter = mObjects.begin();
|
||||
while (iter!=mObjects.end())
|
||||
{
|
||||
if (iter->second->referenceDataChanged (topLeft, bottomRight))
|
||||
modified = true;
|
||||
|
@ -171,23 +178,30 @@ bool CSVRender::Cell::referenceDataChanged (const QModelIndex& topLeft,
|
|||
|
||||
if (iter2!=ids.end())
|
||||
{
|
||||
if (iter2->second)
|
||||
{
|
||||
removeObject (iter->first);
|
||||
modified = true;
|
||||
}
|
||||
|
||||
bool deleted = iter2->second;
|
||||
ids.erase (iter2);
|
||||
|
||||
if (deleted)
|
||||
{
|
||||
iter = removeObject (iter);
|
||||
modified = true;
|
||||
continue;
|
||||
}
|
||||
}
|
||||
|
||||
++iter;
|
||||
}
|
||||
|
||||
// add new objects
|
||||
for (std::map<std::string, bool>::iterator iter (ids.begin()); iter!=ids.end(); ++iter)
|
||||
{
|
||||
mObjects.insert (std::make_pair (
|
||||
iter->first, new Object (mData, mCellNode, iter->first, false)));
|
||||
if (!iter->second)
|
||||
{
|
||||
mObjects.insert (std::make_pair (
|
||||
iter->first, new Object (mData, mCellNode, iter->first, false)));
|
||||
|
||||
modified = true;
|
||||
modified = true;
|
||||
}
|
||||
}
|
||||
|
||||
return modified;
|
||||
|
|
|
@ -49,6 +49,10 @@ namespace CSVRender
|
|||
/// \return Was the object deleted?
|
||||
bool removeObject (const std::string& id);
|
||||
|
||||
// Remove object and return iterator to next object.
|
||||
std::map<std::string, Object *>::iterator removeObject (
|
||||
std::map<std::string, Object *>::iterator iter);
|
||||
|
||||
/// Add objects from reference table that are within this cell.
|
||||
///
|
||||
/// \return Have any objects been added?
|
||||
|
|
Loading…
Reference in a new issue