mirror of
https://github.com/OpenMW/openmw.git
synced 2025-10-24 03:56:37 +00:00
ESMStore: fill mIds in setUp()
This commit is contained in:
parent
ed27f0da25
commit
b856460f86
2 changed files with 18 additions and 14 deletions
|
@ -114,10 +114,6 @@ void ESMStore::load(ESM::ESMReader &esm, Loading::Listener* listener)
|
|||
} else {
|
||||
dialogue = 0;
|
||||
}
|
||||
// Insert the reference into the global lookup
|
||||
if (!id.mId.empty() && isCacheableRecord(n.val)) {
|
||||
mIds[Misc::StringUtils::lowerCase (id.mId)] = n.val;
|
||||
}
|
||||
}
|
||||
listener->setProgress(static_cast<size_t>(esm.getFileOffset() / (float)esm.getFileSize() * 1000));
|
||||
}
|
||||
|
@ -125,9 +121,20 @@ void ESMStore::load(ESM::ESMReader &esm, Loading::Listener* listener)
|
|||
|
||||
void ESMStore::setUp()
|
||||
{
|
||||
std::map<int, StoreBase *>::iterator it = mStores.begin();
|
||||
for (; it != mStores.end(); ++it) {
|
||||
it->second->setUp();
|
||||
mIds.clear();
|
||||
|
||||
std::map<int, StoreBase *>::iterator storeIt = mStores.begin();
|
||||
for (; storeIt != mStores.end(); ++storeIt) {
|
||||
if (isCacheableRecord(storeIt->first))
|
||||
{
|
||||
std::vector<std::string> identifiers;
|
||||
storeIt->second->listIdentifier(identifiers);
|
||||
|
||||
for (std::vector<std::string>::const_iterator record = identifiers.begin(); record != identifiers.end(); ++record)
|
||||
mIds[*record] = storeIt->first;
|
||||
}
|
||||
|
||||
storeIt->second->setUp();
|
||||
}
|
||||
mSkills.setUp();
|
||||
mMagicEffects.setUp();
|
||||
|
@ -189,18 +196,13 @@ void ESMStore::setUp()
|
|||
case ESM::REC_LEVC:
|
||||
|
||||
{
|
||||
RecordId id = mStores[type]->read (reader);
|
||||
|
||||
// FIXME: there might be stale dynamic IDs in mIds from an earlier savegame
|
||||
// that really should be cleared instead of just overwritten
|
||||
|
||||
mIds[id.mId] = type;
|
||||
mStores[type]->read (reader);
|
||||
}
|
||||
|
||||
if (type==ESM::REC_NPC_)
|
||||
{
|
||||
// NPC record will always be last and we know that there can be only one
|
||||
// dynamic NPC record (player) -> We are done here with dynamic record laoding
|
||||
// dynamic NPC record (player) -> We are done here with dynamic record loading
|
||||
setUp();
|
||||
|
||||
const ESM::NPC *player = mNpcs.find ("player");
|
||||
|
|
|
@ -32,6 +32,8 @@ namespace MWWorld
|
|||
virtual ~StoreBase() {}
|
||||
|
||||
virtual void setUp() {}
|
||||
|
||||
/// List identifiers of records contained in this Store (case-smashed). No-op for Stores that don't use string IDs.
|
||||
virtual void listIdentifier(std::vector<std::string> &list) const {}
|
||||
|
||||
virtual size_t getSize() const = 0;
|
||||
|
|
Loading…
Reference in a new issue