mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-26 13:56:37 +00:00 
			
		
		
		
	merge land tables
This commit is contained in:
		
							parent
							
								
									85f6bb892b
								
							
						
					
					
						commit
						a8dc1c1198
					
				
					 5 changed files with 115 additions and 4 deletions
				
			
		|  | @ -40,10 +40,9 @@ CSMTools::MergeOperation::MergeOperation (CSMDoc::Document& document, ToUTF8::Fr | ||||||
|     appendStage (new MergeReferencesStage (mState)); |     appendStage (new MergeReferencesStage (mState)); | ||||||
|     appendStage (new ListLandTexturesMergeStage (mState)); |     appendStage (new ListLandTexturesMergeStage (mState)); | ||||||
|     appendStage (new MergeLandTexturesStage (mState)); |     appendStage (new MergeLandTexturesStage (mState)); | ||||||
|  |     appendStage (new MergeLandStage (mState)); | ||||||
| 
 | 
 | ||||||
|     appendStage (new FinishMergedDocumentStage (mState, encoding)); |     appendStage (new FinishMergedDocumentStage (mState, encoding)); | ||||||
| 
 |  | ||||||
|     /// \todo Land
 |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CSMTools::MergeOperation::setTarget (std::auto_ptr<CSMDoc::Document> document) | void CSMTools::MergeOperation::setTarget (std::auto_ptr<CSMDoc::Document> document) | ||||||
|  |  | ||||||
|  | @ -153,12 +153,20 @@ CSMTools::MergeLandTexturesStage::MergeLandTexturesStage (MergeState& state) | ||||||
| 
 | 
 | ||||||
| int CSMTools::MergeLandTexturesStage::setup() | int CSMTools::MergeLandTexturesStage::setup() | ||||||
| { | { | ||||||
|     mNext = mState.mTextureIndices.begin(); |     // Should use the size of mState.mTextureIndices instead, but that is not available at this
 | ||||||
|     return mState.mTextureIndices.size(); |     // point. Unless there are any errors in the land and land texture records this will not
 | ||||||
|  |     // make a difference.
 | ||||||
|  |     return mState.mSource.getData().getLandTextures().getSize(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CSMTools::MergeLandTexturesStage::perform (int stage, CSMDoc::Messages& messages) | void CSMTools::MergeLandTexturesStage::perform (int stage, CSMDoc::Messages& messages) | ||||||
| { | { | ||||||
|  |     if (stage==0) | ||||||
|  |         mNext = mState.mTextureIndices.begin(); | ||||||
|  | 
 | ||||||
|  |     if (mNext==mState.mTextureIndices.end()) | ||||||
|  |         return; | ||||||
|  | 
 | ||||||
|     mNext->second = stage; |     mNext->second = stage; | ||||||
| 
 | 
 | ||||||
|     std::ostringstream stream; |     std::ostringstream stream; | ||||||
|  | @ -183,3 +191,55 @@ void CSMTools::MergeLandTexturesStage::perform (int stage, CSMDoc::Messages& mes | ||||||
| 
 | 
 | ||||||
|     ++mNext; |     ++mNext; | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | CSMTools::MergeLandStage::MergeLandStage (MergeState& state) : mState (state) {} | ||||||
|  | 
 | ||||||
|  | int CSMTools::MergeLandStage::setup() | ||||||
|  | { | ||||||
|  |     return mState.mSource.getData().getLand().getSize(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void CSMTools::MergeLandStage::perform (int stage, CSMDoc::Messages& messages) | ||||||
|  | { | ||||||
|  |     const CSMWorld::Record<CSMWorld::Land>& record = | ||||||
|  |         mState.mSource.getData().getLand().getRecord (stage); | ||||||
|  | 
 | ||||||
|  |     if (!record.isDeleted()) | ||||||
|  |     { | ||||||
|  |         const CSMWorld::Land& land = record.get(); | ||||||
|  | 
 | ||||||
|  |         land.loadData (ESM::Land::DATA_VCLR | ESM::Land::DATA_VHGT | ESM::Land::DATA_VNML | | ||||||
|  |             ESM::Land::DATA_VTEX | ESM::Land::DATA_WNAM); | ||||||
|  | 
 | ||||||
|  |         CSMWorld::Land newLand (land); | ||||||
|  | 
 | ||||||
|  |         newLand.mEsm = 0; // avoid potential dangling pointer (ESMReader isn't needed anyway,
 | ||||||
|  |                           // because record is already fully loaded)
 | ||||||
|  |         newLand.mPlugin = 0; | ||||||
|  | 
 | ||||||
|  |         // adjust land texture references
 | ||||||
|  |         if (ESM::Land::LandData *data = newLand.getLandData()) | ||||||
|  |         { | ||||||
|  |             std::pair<uint16_t, int> key; | ||||||
|  |             key.second = land.mPlugin; | ||||||
|  | 
 | ||||||
|  |             for (int i=0; i<ESM::Land::LAND_NUM_TEXTURES; ++i) | ||||||
|  |             { | ||||||
|  |                 key.first = data->mTextures[i]; | ||||||
|  |                 std::map<std::pair<uint16_t, int>, int>::const_iterator iter = | ||||||
|  |                     mState.mTextureIndices.find (key); | ||||||
|  | 
 | ||||||
|  |                 if (iter!=mState.mTextureIndices.end()) | ||||||
|  |                     data->mTextures[i] = iter->second; | ||||||
|  |                 else | ||||||
|  |                     data->mTextures[i] = 0; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         CSMWorld::Record<CSMWorld::Land> newRecord ( | ||||||
|  |             CSMWorld::RecordBase::State_ModifiedOnly, 0, &newLand); | ||||||
|  | 
 | ||||||
|  |         mState.mTarget->getData().getLand().appendRecord (newRecord); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @ -146,6 +146,21 @@ namespace CSMTools | ||||||
|             virtual void perform (int stage, CSMDoc::Messages& messages); |             virtual void perform (int stage, CSMDoc::Messages& messages); | ||||||
|             ///< Messages resulting from this stage will be appended to \a messages.
 |             ///< Messages resulting from this stage will be appended to \a messages.
 | ||||||
|     }; |     }; | ||||||
|  | 
 | ||||||
|  |     class MergeLandStage : public CSMDoc::Stage | ||||||
|  |     { | ||||||
|  |             MergeState& mState; | ||||||
|  | 
 | ||||||
|  |         public: | ||||||
|  | 
 | ||||||
|  |             MergeLandStage (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 | #endif | ||||||
|  |  | ||||||
|  | @ -256,4 +256,30 @@ bool Land::isDataLoaded(int flags) const | ||||||
|     { |     { | ||||||
|         return mLandData; |         return mLandData; | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     Land::LandData *Land::getLandData() | ||||||
|  |     { | ||||||
|  |         return mLandData; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     void Land::add (int flags) | ||||||
|  |     { | ||||||
|  |         if (!mLandData) | ||||||
|  |             mLandData = new LandData; | ||||||
|  | 
 | ||||||
|  |         mDataTypes |= flags; | ||||||
|  |         mDataLoaded |= flags; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     void Land::remove (int flags) | ||||||
|  |     { | ||||||
|  |         mDataTypes &= ~flags; | ||||||
|  |         mDataLoaded &= ~flags; | ||||||
|  | 
 | ||||||
|  |         if (!mDataLoaded) | ||||||
|  |         { | ||||||
|  |             delete mLandData; | ||||||
|  |             mLandData = 0; | ||||||
|  |         } | ||||||
|  |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -127,6 +127,17 @@ struct Land | ||||||
|         /// Return land data without loading first anything. Can return a 0-pointer.
 |         /// Return land data without loading first anything. Can return a 0-pointer.
 | ||||||
|         const LandData *getLandData() const; |         const LandData *getLandData() const; | ||||||
| 
 | 
 | ||||||
|  |         /// Return land data without loading first anything. Can return a 0-pointer.
 | ||||||
|  |         LandData *getLandData(); | ||||||
|  | 
 | ||||||
|  |         /// \attention Must not be called on objects that aren't fully loaded.
 | ||||||
|  |         ///
 | ||||||
|  |         /// \note Added data fields will be uninitialised
 | ||||||
|  |         void add (int flags); | ||||||
|  | 
 | ||||||
|  |         /// \attention Must not be called on objects that aren't fully loaded.
 | ||||||
|  |         void remove (int flags); | ||||||
|  | 
 | ||||||
|     private: |     private: | ||||||
| 
 | 
 | ||||||
|         /// Loads data and marks it as loaded
 |         /// Loads data and marks it as loaded
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue