mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-25 15:56:37 +00:00 
			
		
		
		
	Merge remote-tracking branch 'zini/master' into animation2
This commit is contained in:
		
						commit
						94be45e07e
					
				
					 3 changed files with 49 additions and 25 deletions
				
			
		|  | @ -139,28 +139,45 @@ namespace MWScript | |||
|     } | ||||
| 
 | ||||
|     Compiler::Locals& ScriptManager::getLocals (const std::string& name) | ||||
|     { | ||||
|         { | ||||
|             ScriptCollection::iterator iter = mScripts.find (name); | ||||
| 
 | ||||
|         if (iter==mScripts.end()) | ||||
|         { | ||||
|             if (!compile (name)) | ||||
|             { | ||||
|                 /// \todo Handle case of cyclic member variable access. Currently this could look up
 | ||||
|                 /// the whole application in an endless recursion.
 | ||||
| 
 | ||||
|                 // failed -> ignore script from now on.
 | ||||
|                 std::vector<Interpreter::Type_Code> empty; | ||||
|                 mScripts.insert (std::make_pair (name, std::make_pair (empty, Compiler::Locals()))); | ||||
|                 throw std::runtime_error ("failed to compile script " + name); | ||||
|             } | ||||
| 
 | ||||
|             iter = mScripts.find (name); | ||||
|         } | ||||
| 
 | ||||
|             if (iter!=mScripts.end()) | ||||
|                 return iter->second.second; | ||||
|         } | ||||
| 
 | ||||
|         { | ||||
|             std::map<std::string, Compiler::Locals>::iterator iter = mOtherLocals.find (name); | ||||
| 
 | ||||
|             if (iter!=mOtherLocals.end()) | ||||
|                 return iter->second; | ||||
|         } | ||||
| 
 | ||||
|         Compiler::Locals locals; | ||||
| 
 | ||||
|         if (const ESM::Script *script = mStore.get<ESM::Script>().find (name)) | ||||
|         { | ||||
|             int index = 0; | ||||
| 
 | ||||
|             for (int i=0; i<script->mData.mNumShorts; ++i) | ||||
|                 locals.declare ('s', script->mVarNames[index++]); | ||||
| 
 | ||||
|             for (int i=0; i<script->mData.mNumLongs; ++i) | ||||
|                 locals.declare ('l', script->mVarNames[index++]); | ||||
| 
 | ||||
|             for (int i=0; i<script->mData.mNumFloats; ++i) | ||||
|                 locals.declare ('f', script->mVarNames[index++]); | ||||
| 
 | ||||
|             std::map<std::string, Compiler::Locals>::iterator iter = | ||||
|                 mOtherLocals.insert (std::make_pair (name, locals)).first; | ||||
| 
 | ||||
|             return iter->second; | ||||
|         } | ||||
| 
 | ||||
|         throw std::logic_error ("script " + name + " does not exist"); | ||||
|     } | ||||
| 
 | ||||
|     GlobalScripts& ScriptManager::getGlobalScripts() | ||||
|     { | ||||
|         return mGlobalScripts; | ||||
|  |  | |||
|  | @ -47,6 +47,7 @@ namespace MWScript | |||
| 
 | ||||
|             ScriptCollection mScripts; | ||||
|             GlobalScripts mGlobalScripts; | ||||
|             std::map<std::string, Compiler::Locals> mOtherLocals; | ||||
| 
 | ||||
|         public: | ||||
| 
 | ||||
|  |  | |||
|  | @ -220,9 +220,15 @@ namespace MWWorld | |||
|     template <> | ||||
|     inline void Store<ESM::Dialogue>::load(ESM::ESMReader &esm, const std::string &id) { | ||||
|         std::string idLower = Misc::StringUtils::lowerCase(id); | ||||
|         mStatic[idLower] = ESM::Dialogue(); | ||||
|         mStatic[idLower].mId = id; // don't smash case here, as this line is printed... I think
 | ||||
|         mStatic[idLower].load(esm); | ||||
| 
 | ||||
|         std::map<std::string, ESM::Dialogue>::iterator it = mStatic.find(idLower); | ||||
|         if (it == mStatic.end()) { | ||||
|             it = mStatic.insert( std::make_pair( idLower, ESM::Dialogue() ) ).first; | ||||
|             it->second.mId = id; // don't smash case here, as this line is printed... I think
 | ||||
|         } | ||||
| 
 | ||||
|         //I am not sure is it need to load the dialog from a plugin if it was already loaded from prevois plugins
 | ||||
|         it->second.load(esm); | ||||
|     } | ||||
| 
 | ||||
|     template <> | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue