Fix dynamically placed objects being discarded when loading game

This commit is contained in:
scrawl 2014-04-26 03:15:50 +02:00
parent f05606657c
commit cd1b4218e7

View file

@ -52,7 +52,7 @@ namespace
iter!=collection.mList.end(); ++iter) iter!=collection.mList.end(); ++iter)
{ {
if (iter->mData.getCount()==0 && iter->mRef.mRefNum.mContentFile==-1) if (iter->mData.getCount()==0 && iter->mRef.mRefNum.mContentFile==-1)
continue; // deleted file that did not came from a content file -> ignore continue; // deleted reference that did not come from a content file -> ignore
RecordType state; RecordType state;
iter->save (state); iter->save (state);
@ -72,13 +72,17 @@ namespace
RecordType state; RecordType state;
state.load (reader); state.load (reader);
std::map<int, int>::const_iterator iter = // If the reference came from a content file, make sure this content file is loaded
contentFileMap.find (state.mRef.mRefNum.mContentFile); if (state.mRef.mRefNum.mContentFile != -1)
{
std::map<int, int>::const_iterator iter =
contentFileMap.find (state.mRef.mRefNum.mContentFile);
if (iter==contentFileMap.end()) if (iter==contentFileMap.end())
return; // content file has been removed -> skip return; // content file has been removed -> skip
state.mRef.mRefNum.mContentFile = iter->second; state.mRef.mRefNum.mContentFile = iter->second;
}
if (!MWWorld::LiveCellRef<T>::checkState (state)) if (!MWWorld::LiveCellRef<T>::checkState (state))
return; // not valid anymore with current content files -> skip return; // not valid anymore with current content files -> skip