mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-25 22:26:37 +00:00 
			
		
		
		
	Journal verifier
This commit is contained in:
		
							parent
							
								
									f4ed389496
								
							
						
					
					
						commit
						1ae402476d
					
				
					 4 changed files with 118 additions and 1 deletions
				
			
		|  | @ -42,7 +42,7 @@ opencs_units_noqt (model/tools | ||||||
|     mandatoryid skillcheck classcheck factioncheck racecheck soundcheck regioncheck |     mandatoryid skillcheck classcheck factioncheck racecheck soundcheck regioncheck | ||||||
|     birthsigncheck spellcheck referencecheck referenceablecheck scriptcheck bodypartcheck |     birthsigncheck spellcheck referencecheck referenceablecheck scriptcheck bodypartcheck | ||||||
|     startscriptcheck search searchoperation searchstage pathgridcheck soundgencheck magiceffectcheck |     startscriptcheck search searchoperation searchstage pathgridcheck soundgencheck magiceffectcheck | ||||||
|     mergestages gmstcheck topicinfocheck |     mergestages gmstcheck topicinfocheck journalcheck | ||||||
|     ) |     ) | ||||||
| 
 | 
 | ||||||
| opencs_hdrs_noqt (model/tools | opencs_hdrs_noqt (model/tools | ||||||
|  |  | ||||||
							
								
								
									
										79
									
								
								apps/opencs/model/tools/journalcheck.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										79
									
								
								apps/opencs/model/tools/journalcheck.cpp
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,79 @@ | ||||||
|  | #include "journalcheck.hpp" | ||||||
|  | 
 | ||||||
|  | #include <set> | ||||||
|  | #include <sstream> | ||||||
|  | 
 | ||||||
|  | CSMTools::JournalCheckStage::JournalCheckStage(const CSMWorld::IdCollection<ESM::Dialogue> &journals, | ||||||
|  |     const CSMWorld::InfoCollection& journalInfos) | ||||||
|  |     : mJournals(journals), mJournalInfos(journalInfos) | ||||||
|  | {} | ||||||
|  | 
 | ||||||
|  | int CSMTools::JournalCheckStage::setup() | ||||||
|  | { | ||||||
|  |     return mJournals.getSize(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void CSMTools::JournalCheckStage::perform(int stage, CSMDoc::Messages& messages) | ||||||
|  | { | ||||||
|  |     const CSMWorld::Record<ESM::Dialogue> &journalRecord = mJournals.getRecord(stage); | ||||||
|  | 
 | ||||||
|  |     if (journalRecord.isDeleted()) | ||||||
|  |         return; | ||||||
|  | 
 | ||||||
|  |     const ESM::Dialogue &journal = journalRecord.get(); | ||||||
|  |     int statusNamedCount = 0; | ||||||
|  |     int totalInfoCount = 0; | ||||||
|  |     std::set<int> questIndices; | ||||||
|  | 
 | ||||||
|  |     CSMWorld::InfoCollection::Range range = mJournalInfos.getTopicRange(journal.mId); | ||||||
|  | 
 | ||||||
|  |     for (CSMWorld::InfoCollection::RecordConstIterator it = range.first; it != range.second; ++it) | ||||||
|  |     { | ||||||
|  |         const CSMWorld::Record<CSMWorld::Info> infoRecord = (*it); | ||||||
|  | 
 | ||||||
|  |         if (infoRecord.isDeleted()) | ||||||
|  |             continue; | ||||||
|  | 
 | ||||||
|  |         const CSMWorld::Info& journalInfo = infoRecord.get(); | ||||||
|  | 
 | ||||||
|  |         totalInfoCount += 1; | ||||||
|  | 
 | ||||||
|  |         if (journalInfo.mQuestStatus == ESM::DialInfo::QS_Name) | ||||||
|  |         { | ||||||
|  |             statusNamedCount += 1; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         if (journalInfo.mResponse.empty()) | ||||||
|  |         { | ||||||
|  |             CSMWorld::UniversalId id(CSMWorld::UniversalId::Type_JournalInfo, journalInfo.mId); | ||||||
|  | 
 | ||||||
|  |             messages.add(id, "Journal Info: missing description", "", CSMDoc::Message::Severity_Warning); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         std::pair<std::set<int>::iterator, bool> result = questIndices.insert(journalInfo.mData.mJournalIndex); | ||||||
|  | 
 | ||||||
|  |         // Duplicate index
 | ||||||
|  |         if (result.second == false) | ||||||
|  |         { | ||||||
|  |             CSMWorld::UniversalId id(CSMWorld::UniversalId::Type_JournalInfo, journalInfo.mId); | ||||||
|  | 
 | ||||||
|  |             std::ostringstream stream; | ||||||
|  |             stream << "Journal: duplicated quest index " << journalInfo.mData.mJournalIndex; | ||||||
|  | 
 | ||||||
|  |             messages.add(id, stream.str(), "", CSMDoc::Message::Severity_Error); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     if (totalInfoCount == 0) | ||||||
|  |     { | ||||||
|  |         CSMWorld::UniversalId id(CSMWorld::UniversalId::Type_Journal, journal.mId); | ||||||
|  | 
 | ||||||
|  |         messages.add(id, "Journal: no defined Journal Infos", "", CSMDoc::Message::Severity_Warning); | ||||||
|  |     } | ||||||
|  |     else if (statusNamedCount > 1) | ||||||
|  |     { | ||||||
|  |         CSMWorld::UniversalId id(CSMWorld::UniversalId::Type_Journal, journal.mId); | ||||||
|  | 
 | ||||||
|  |         messages.add(id, "Journal: multiple infos with quest status \"Named\"", "", CSMDoc::Message::Severity_Error); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										35
									
								
								apps/opencs/model/tools/journalcheck.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								apps/opencs/model/tools/journalcheck.hpp
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,35 @@ | ||||||
|  | #ifndef CSM_TOOLS_JOURNALCHECK_H | ||||||
|  | #define CSM_TOOLS_JOURNALCHECK_H | ||||||
|  | 
 | ||||||
|  | #include <components/esm/loaddial.hpp> | ||||||
|  | 
 | ||||||
|  | #include "../world/idcollection.hpp" | ||||||
|  | #include "../world/infocollection.hpp" | ||||||
|  | 
 | ||||||
|  | #include "../doc/stage.hpp" | ||||||
|  | 
 | ||||||
|  | namespace CSMTools | ||||||
|  | { | ||||||
|  |     /// \brief VerifyStage: make sure that journal infos are good
 | ||||||
|  |     class JournalCheckStage : public CSMDoc::Stage | ||||||
|  |     { | ||||||
|  |     public: | ||||||
|  | 
 | ||||||
|  |         JournalCheckStage(const CSMWorld::IdCollection<ESM::Dialogue>& journals, | ||||||
|  |             const CSMWorld::InfoCollection& journalInfos); | ||||||
|  | 
 | ||||||
|  |         virtual int setup(); | ||||||
|  |         ///< \return number of steps
 | ||||||
|  | 
 | ||||||
|  |         virtual void perform(int stage, CSMDoc::Messages& messages); | ||||||
|  |         ///< Messages resulting from this stage will be appended to \a messages
 | ||||||
|  | 
 | ||||||
|  |     private: | ||||||
|  | 
 | ||||||
|  |         const CSMWorld::IdCollection<ESM::Dialogue>& mJournals; | ||||||
|  |         const CSMWorld::InfoCollection& mJournalInfos; | ||||||
|  | 
 | ||||||
|  |     }; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #endif | ||||||
|  | @ -31,6 +31,7 @@ | ||||||
| #include "mergeoperation.hpp" | #include "mergeoperation.hpp" | ||||||
| #include "gmstcheck.hpp" | #include "gmstcheck.hpp" | ||||||
| #include "topicinfocheck.hpp" | #include "topicinfocheck.hpp" | ||||||
|  | #include "journalcheck.hpp" | ||||||
| 
 | 
 | ||||||
| CSMDoc::OperationHolder *CSMTools::Tools::get (int type) | CSMDoc::OperationHolder *CSMTools::Tools::get (int type) | ||||||
| { | { | ||||||
|  | @ -128,6 +129,8 @@ CSMDoc::OperationHolder *CSMTools::Tools::getVerifier() | ||||||
|                                                                   mData.getReferenceables().getDataSet(), |                                                                   mData.getReferenceables().getDataSet(), | ||||||
|                                                                   mData.getResources (CSMWorld::UniversalId::Type_SoundsRes))); |                                                                   mData.getResources (CSMWorld::UniversalId::Type_SoundsRes))); | ||||||
| 
 | 
 | ||||||
|  |         mVerifierOperation->appendStage (new JournalCheckStage(mData.getJournals(), mData.getJournalInfos())); | ||||||
|  | 
 | ||||||
|         mVerifier.setOperation (mVerifierOperation); |         mVerifier.setOperation (mVerifierOperation); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue