mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-26 04:26:38 +00:00 
			
		
		
		
	fix: topics who should not be displayed are not displayed anymore.
This commit is contained in:
		
							parent
							
								
									2707391535
								
							
						
					
					
						commit
						d4f3430fc6
					
				
					 1 changed files with 6 additions and 5 deletions
				
			
		|  | @ -517,7 +517,6 @@ namespace MWDialogue | |||
|                 return false; | ||||
| 
 | ||||
|         // TODO check DATAstruct
 | ||||
| 
 | ||||
|         for (std::vector<ESM::DialInfo::SelectStruct>::const_iterator iter (info.selects.begin()); | ||||
|             iter != info.selects.end(); ++iter) | ||||
|             if (!isMatching (actor, *iter)) | ||||
|  | @ -691,7 +690,8 @@ namespace MWDialogue | |||
|     void DialogueManager::updateTopics() | ||||
|     { | ||||
|         std::list<std::string> keywordList; | ||||
| 
 | ||||
|         int choice = mChoice; | ||||
|         mChoice = -1; | ||||
|         actorKnownTopics.clear(); | ||||
|         MWGui::DialogueWindow* win = mEnvironment.mWindowManager->getDialogueWindow(); | ||||
|         ESMS::RecListT<ESM::Dialogue>::MapType dialogueList = mEnvironment.mWorld->getStore().dialogs.list; | ||||
|  | @ -703,7 +703,7 @@ namespace MWDialogue | |||
|                 for (std::vector<ESM::DialInfo>::const_iterator iter (it->second.mInfo.begin()); | ||||
|                     iter!=it->second.mInfo.end(); ++iter) | ||||
|                 { | ||||
|                     if (isMatching (mActor, *iter) && functionFilter(mActor,*iter,false)) | ||||
|                     if (isMatching (mActor, *iter) && functionFilter(mActor,*iter,true)) | ||||
|                     { | ||||
|                          actorKnownTopics.push_back(it->first); | ||||
|                         //does the player know the topic?
 | ||||
|  | @ -717,6 +717,7 @@ namespace MWDialogue | |||
|             } | ||||
|         } | ||||
|         win->setKeywords(keywordList); | ||||
|         mChoice = choice; | ||||
|     } | ||||
| 
 | ||||
|     void DialogueManager::keywordSelected(std::string keyword) | ||||
|  | @ -726,10 +727,9 @@ namespace MWDialogue | |||
|             if(mDialogueMap.find(keyword) != mDialogueMap.end()) | ||||
|             { | ||||
|                 ESM::Dialogue ndialogue = mDialogueMap[keyword]; | ||||
|                 std::vector<ESM::DialInfo>::const_iterator iter; | ||||
|                 if(ndialogue.type == ESM::Dialogue::Topic) | ||||
|                 { | ||||
|                     for (iter  = ndialogue.mInfo.begin(); | ||||
|                     for (std::vector<ESM::DialInfo>::const_iterator iter  = ndialogue.mInfo.begin(); | ||||
|                         iter!=ndialogue.mInfo.end(); ++iter) | ||||
|                     { | ||||
|                         if (isMatching (mActor, *iter) && functionFilter(mActor,*iter,true)) | ||||
|  | @ -753,6 +753,7 @@ namespace MWDialogue | |||
|                 } | ||||
|             } | ||||
|         } | ||||
|         std::cout << std::endl << std::endl; | ||||
|         updateTopics(); | ||||
|     } | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue