mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-25 14:56:37 +00:00 
			
		
		
		
	merge references tables
This commit is contained in:
		
							parent
							
								
									845cafd61c
								
							
						
					
					
						commit
						a97a632aa7
					
				
					 3 changed files with 53 additions and 2 deletions
				
			
		|  | @ -35,8 +35,9 @@ CSMTools::MergeOperation::MergeOperation (CSMDoc::Document& document, ToUTF8::Fr | |||
|     appendStage (new MergeIdCollectionStage<CSMWorld::Info, CSMWorld::InfoCollection> (mState, &CSMWorld::Data::getTopicInfos)); | ||||
|     appendStage (new MergeIdCollectionStage<CSMWorld::Info, CSMWorld::InfoCollection> (mState, &CSMWorld::Data::getJournalInfos)); | ||||
|     appendStage (new MergeRefIdsStage (mState)); | ||||
|     appendStage (new MergeReferencesStage (mState)); | ||||
| 
 | ||||
|     /// \todo References, Land, LandTextures
 | ||||
|     /// \todo Land, LandTextures
 | ||||
| } | ||||
| 
 | ||||
| void CSMTools::MergeOperation::setTarget (std::auto_ptr<CSMDoc::Document> document) | ||||
|  |  | |||
|  | @ -1,6 +1,8 @@ | |||
| 
 | ||||
| #include "mergestages.hpp" | ||||
| 
 | ||||
| #include <components/misc/stringops.hpp> | ||||
| 
 | ||||
| #include "mergestate.hpp" | ||||
| 
 | ||||
| #include "../doc/document.hpp" | ||||
|  | @ -53,3 +55,35 @@ void CSMTools::MergeRefIdsStage::perform (int stage, CSMDoc::Messages& messages) | |||
|     mState.mSource.getData().getReferenceables().copyTo ( | ||||
|         stage, mState.mTarget->getData().getReferenceables()); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| CSMTools::MergeReferencesStage::MergeReferencesStage (MergeState& state) | ||||
| : mState (state) | ||||
| {} | ||||
| 
 | ||||
| int CSMTools::MergeReferencesStage::setup() | ||||
| { | ||||
|     mIndex.clear(); | ||||
|     return mState.mSource.getData().getReferences().getSize(); | ||||
| } | ||||
| 
 | ||||
| void CSMTools::MergeReferencesStage::perform (int stage, CSMDoc::Messages& messages) | ||||
| { | ||||
|     const CSMWorld::Record<CSMWorld::CellRef>& record = | ||||
|         mState.mSource.getData().getReferences().getRecord (stage); | ||||
| 
 | ||||
|     if (!record.isDeleted()) | ||||
|     { | ||||
|         CSMWorld::CellRef ref = record.get(); | ||||
| 
 | ||||
|         ref.mOriginalCell = ref.mCell; | ||||
| 
 | ||||
|         ref.mRefNum.mIndex = mIndex[Misc::StringUtils::lowerCase (ref.mCell)]++; | ||||
|         ref.mRefNum.mContentFile = 0; | ||||
| 
 | ||||
|         CSMWorld::Record<CSMWorld::CellRef> newRecord ( | ||||
|             CSMWorld::RecordBase::State_ModifiedOnly, 0, &ref); | ||||
| 
 | ||||
|         mState.mTarget->getData().getReferences().appendRecord (newRecord); | ||||
|     } | ||||
| } | ||||
|  |  | |||
|  | @ -2,6 +2,7 @@ | |||
| #define CSM_TOOLS_MERGESTAGES_H | ||||
| 
 | ||||
| #include <algorithm> | ||||
| #include <map> | ||||
| 
 | ||||
| #include <components/to_utf8/to_utf8.hpp> | ||||
| 
 | ||||
|  | @ -69,7 +70,6 @@ namespace CSMTools | |||
|             target.appendRecord (CSMWorld::Record<RecordType> (CSMWorld::RecordBase::State_ModifiedOnly, 0, &record.get())); | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|     class MergeRefIdsStage : public CSMDoc::Stage | ||||
|     { | ||||
|             MergeState& mState; | ||||
|  | @ -84,6 +84,22 @@ namespace CSMTools | |||
|             virtual void perform (int stage, CSMDoc::Messages& messages); | ||||
|             ///< Messages resulting from this stage will be appended to \a messages.
 | ||||
|     }; | ||||
| 
 | ||||
|     class MergeReferencesStage : public CSMDoc::Stage | ||||
|     { | ||||
|             MergeState& mState; | ||||
|             std::map<std::string, int> mIndex; | ||||
| 
 | ||||
|         public: | ||||
| 
 | ||||
|             MergeReferencesStage (MergeState& state); | ||||
| 
 | ||||
|             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.
 | ||||
|     }; | ||||
| } | ||||
| 
 | ||||
| #endif | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue