mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-26 12:26: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