mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-25 07:56:37 +00:00 
			
		
		
		
	added missing implementation for CSMWorld::ScriptContext::getMemberType
This commit is contained in:
		
							parent
							
								
									d213c6c36a
								
							
						
					
					
						commit
						0a8ffbfb1d
					
				
					 2 changed files with 58 additions and 1 deletions
				
			
		|  | @ -5,6 +5,10 @@ | |||
| 
 | ||||
| #include <components/misc/stringops.hpp> | ||||
| 
 | ||||
| #include <components/compiler/quickfileparser.hpp> | ||||
| #include <components/compiler/nullerrorhandler.hpp> | ||||
| #include <components/compiler/scanner.hpp> | ||||
| 
 | ||||
| #include "data.hpp" | ||||
| 
 | ||||
| CSMWorld::ScriptContext::ScriptContext (const Data& data) : mData (data), mIdsUpdated (false) {} | ||||
|  | @ -36,7 +40,57 @@ char CSMWorld::ScriptContext::getGlobalType (const std::string& name) const | |||
| std::pair<char, bool> CSMWorld::ScriptContext::getMemberType (const std::string& name, | ||||
|     const std::string& id) const | ||||
| { | ||||
|     return std::make_pair (' ', false); | ||||
|     /// \todo invalidate locals cache on change to scripts
 | ||||
| 
 | ||||
|     std::string id2 = Misc::StringUtils::lowerCase (id); | ||||
| 
 | ||||
|     int index = mData.getScripts().searchId (id2); | ||||
|     bool reference = false; | ||||
| 
 | ||||
|     if (index!=-1) | ||||
|     { | ||||
|         // ID is not a script ID. Search for a matching referenceable instead.
 | ||||
|         index = mData.getReferenceables().searchId (id2); | ||||
| 
 | ||||
|         if (index!=-1) | ||||
|         { | ||||
|             // Referenceable found.
 | ||||
|             int columnIndex = mData.getReferenceables().searchColumnIndex (Columns::ColumnId_Script); | ||||
| 
 | ||||
|             if (columnIndex!=-1) | ||||
|             { | ||||
|                 id2 = Misc::StringUtils::lowerCase (mData.getReferenceables(). | ||||
|                     getData (index, columnIndex).toString().toUtf8().constData()); | ||||
| 
 | ||||
|                 if (!id2.empty()) | ||||
|                 { | ||||
|                     // Referenceable has a script -> use it.
 | ||||
|                     index = mData.getScripts().searchId (id2); | ||||
|                     reference = true; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     if (index==-1) | ||||
|         return std::make_pair (' ', false); | ||||
| 
 | ||||
|     std::map<std::string, Compiler::Locals>::iterator iter = mLocals.find (id2); | ||||
| 
 | ||||
|     if (iter==mLocals.end()) | ||||
|     { | ||||
|         Compiler::Locals locals; | ||||
| 
 | ||||
|         Compiler::NullErrorHandler errorHandler; | ||||
|         std::istringstream stream (mData.getScripts().getRecord (index).get().mScriptText); | ||||
|         Compiler::QuickFileParser parser (errorHandler, *this, locals); | ||||
|         Compiler::Scanner scanner (errorHandler, stream, getExtensions()); | ||||
|         scanner.scan (parser); | ||||
| 
 | ||||
|         iter = mLocals.insert (std::make_pair (id2, locals)).first; | ||||
|     } | ||||
| 
 | ||||
|     return std::make_pair (iter->second.getType (Misc::StringUtils::lowerCase (name)), reference); | ||||
| } | ||||
| 
 | ||||
| bool CSMWorld::ScriptContext::isId (const std::string& name) const | ||||
|  |  | |||
|  | @ -3,8 +3,10 @@ | |||
| 
 | ||||
| #include <string> | ||||
| #include <vector> | ||||
| #include <map> | ||||
| 
 | ||||
| #include <components/compiler/context.hpp> | ||||
| #include <components/compiler/locals.hpp> | ||||
| 
 | ||||
| namespace CSMWorld | ||||
| { | ||||
|  | @ -15,6 +17,7 @@ namespace CSMWorld | |||
|             const Data& mData; | ||||
|             mutable std::vector<std::string> mIds; | ||||
|             mutable bool mIdsUpdated; | ||||
|             mutable std::map<std::string, Compiler::Locals> mLocals; | ||||
| 
 | ||||
|         public: | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue