mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-25 22:26:37 +00:00 
			
		
		
		
	Fix incorrect disposition testing and get rid of of a related hack that is no longer needed.
This commit is contained in:
		
							parent
							
								
									09d491d1ba
								
							
						
					
					
						commit
						12691040d1
					
				
					 3 changed files with 8 additions and 9 deletions
				
			
		|  | @ -251,7 +251,7 @@ namespace MWDialogue | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void DialogueManager::executeTopic (const std::string& topic, bool randomResponse) |     void DialogueManager::executeTopic (const std::string& topic) | ||||||
|     { |     { | ||||||
|         Filter filter (mActor, mChoice, mTalkedTo); |         Filter filter (mActor, mChoice, mTalkedTo); | ||||||
| 
 | 
 | ||||||
|  | @ -262,12 +262,9 @@ namespace MWDialogue | ||||||
| 
 | 
 | ||||||
|         MWGui::DialogueWindow* win = MWBase::Environment::get().getWindowManager()->getDialogueWindow(); |         MWGui::DialogueWindow* win = MWBase::Environment::get().getWindowManager()->getDialogueWindow(); | ||||||
| 
 | 
 | ||||||
|         std::vector<const ESM::DialInfo *> infos = filter.list (dialogue, true, true); |         const ESM::DialInfo* info = filter.search(dialogue, true); | ||||||
| 
 |         if (info) | ||||||
|         if (!infos.empty()) |  | ||||||
|         { |         { | ||||||
|             const ESM::DialInfo* info = infos[randomResponse ? std::rand() % infos.size() : 0]; |  | ||||||
| 
 |  | ||||||
|             parseText (info->mResponse); |             parseText (info->mResponse); | ||||||
| 
 | 
 | ||||||
|             std::string title; |             std::string title; | ||||||
|  | @ -509,7 +506,7 @@ namespace MWDialogue | ||||||
|             text = "Bribe"; |             text = "Bribe"; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         executeTopic (text + (success ? " Success" : " Fail"), true); |         executeTopic (text + (success ? " Success" : " Fail")); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     int DialogueManager::getTemporaryDispositionChange() const |     int DialogueManager::getTemporaryDispositionChange() const | ||||||
|  |  | ||||||
|  | @ -44,7 +44,7 @@ namespace MWDialogue | ||||||
|             bool compile (const std::string& cmd,std::vector<Interpreter::Type_Code>& code); |             bool compile (const std::string& cmd,std::vector<Interpreter::Type_Code>& code); | ||||||
|             void executeScript (const std::string& script); |             void executeScript (const std::string& script); | ||||||
| 
 | 
 | ||||||
|             void executeTopic (const std::string& topic, bool randomResponse=false); |             void executeTopic (const std::string& topic); | ||||||
| 
 | 
 | ||||||
|         public: |         public: | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -5,6 +5,7 @@ | ||||||
| #include "../mwbase/world.hpp" | #include "../mwbase/world.hpp" | ||||||
| #include "../mwbase/journal.hpp" | #include "../mwbase/journal.hpp" | ||||||
| #include "../mwbase/mechanicsmanager.hpp" | #include "../mwbase/mechanicsmanager.hpp" | ||||||
|  | #include "../mwbase/dialoguemanager.hpp" | ||||||
| 
 | 
 | ||||||
| #include "../mwworld/class.hpp" | #include "../mwworld/class.hpp" | ||||||
| #include "../mwworld/player.hpp" | #include "../mwworld/player.hpp" | ||||||
|  | @ -133,7 +134,8 @@ bool MWDialogue::Filter::testDisposition (const ESM::DialInfo& info, bool invert | ||||||
|     if (isCreature) |     if (isCreature) | ||||||
|         return true; |         return true; | ||||||
| 
 | 
 | ||||||
|     int actorDisposition = MWBase::Environment::get().getMechanicsManager()->getDerivedDisposition(mActor); |     int actorDisposition = MWBase::Environment::get().getMechanicsManager()->getDerivedDisposition(mActor) | ||||||
|  |             + MWBase::Environment::get().getDialogueManager()->getTemporaryDispositionChange(); | ||||||
|     // For service refusal, the disposition check is inverted. However, a value of 0 still means "always succeed".
 |     // For service refusal, the disposition check is inverted. However, a value of 0 still means "always succeed".
 | ||||||
|     return invert ? (info.mData.mDisposition == 0 || actorDisposition < info.mData.mDisposition) |     return invert ? (info.mData.mDisposition == 0 || actorDisposition < info.mData.mDisposition) | ||||||
|                   : (actorDisposition >= info.mData.mDisposition); |                   : (actorDisposition >= info.mData.mDisposition); | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue