mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-26 20:26: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/misc/stringops.hpp> | ||||||
| 
 | 
 | ||||||
|  | #include <components/compiler/quickfileparser.hpp> | ||||||
|  | #include <components/compiler/nullerrorhandler.hpp> | ||||||
|  | #include <components/compiler/scanner.hpp> | ||||||
|  | 
 | ||||||
| #include "data.hpp" | #include "data.hpp" | ||||||
| 
 | 
 | ||||||
| CSMWorld::ScriptContext::ScriptContext (const Data& data) : mData (data), mIdsUpdated (false) {} | 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, | std::pair<char, bool> CSMWorld::ScriptContext::getMemberType (const std::string& name, | ||||||
|     const std::string& id) const |     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 | bool CSMWorld::ScriptContext::isId (const std::string& name) const | ||||||
|  |  | ||||||
|  | @ -3,8 +3,10 @@ | ||||||
| 
 | 
 | ||||||
| #include <string> | #include <string> | ||||||
| #include <vector> | #include <vector> | ||||||
|  | #include <map> | ||||||
| 
 | 
 | ||||||
| #include <components/compiler/context.hpp> | #include <components/compiler/context.hpp> | ||||||
|  | #include <components/compiler/locals.hpp> | ||||||
| 
 | 
 | ||||||
| namespace CSMWorld | namespace CSMWorld | ||||||
| { | { | ||||||
|  | @ -15,6 +17,7 @@ namespace CSMWorld | ||||||
|             const Data& mData; |             const Data& mData; | ||||||
|             mutable std::vector<std::string> mIds; |             mutable std::vector<std::string> mIds; | ||||||
|             mutable bool mIdsUpdated; |             mutable bool mIdsUpdated; | ||||||
|  |             mutable std::map<std::string, Compiler::Locals> mLocals; | ||||||
| 
 | 
 | ||||||
|         public: |         public: | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue