mirror of
				https://github.com/thunderbrewhq/thunderbrew
				synced 2025-10-26 22:06:06 +03:00 
			
		
		
		
	feat(db): improve accuracy of db records
This commit is contained in:
		
							parent
							
								
									41554f32b4
								
							
						
					
					
						commit
						57db9ca2a5
					
				| @ -101,9 +101,9 @@ void WowClientDB<T>::Load(const char* filename, int32_t linenumber) { | |||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if (columnCount != T::columnCount) { |     if (columnCount != T::GetNumColumns()) { | ||||||
|         // TODO
 |         // TODO
 | ||||||
|         // SErrDisplayAppFatalCustom(0x85100079, "%s has wrong number of columns (found %i, expected %i)", T::GetFilename(), columnCount, T::columnCount);
 |         // SErrDisplayAppFatalCustom(0x85100079, "%s has wrong number of columns (found %i, expected %i)", T::GetFilename(), columnCount, T::GetNumColumns());
 | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -114,9 +114,9 @@ void WowClientDB<T>::Load(const char* filename, int32_t linenumber) { | |||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if (rowSize != T::rowSize) { |     if (rowSize != T::GetRowSize()) { | ||||||
|         // TODO
 |         // TODO
 | ||||||
|         // SErrDisplayAppFatalCustom(0x85100079, "%s has wrong row size (found %i, expected %i)", T::GetFilename(), rowSize, T::rowSize);
 |         // SErrDisplayAppFatalCustom(0x85100079, "%s has wrong row size (found %i, expected %i)", T::GetFilename(), rowSize, T::GetRowSize());
 | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -153,8 +153,8 @@ void WowClientDB<T>::LoadRecords(SFile* f, const char* filename, int32_t linenum | |||||||
|         auto record = &this->m_records[i]; |         auto record = &this->m_records[i]; | ||||||
|         record->Read(f, this->m_strings); |         record->Read(f, this->m_strings); | ||||||
| 
 | 
 | ||||||
|         this->m_maxID = record->m_ID > this->m_maxID ? record->m_ID : this->m_maxID; |         this->m_maxID = record->GetID() > this->m_maxID ? record->GetID() : this->m_maxID; | ||||||
|         this->m_minID = record->m_ID < this->m_minID ? record->m_ID : this->m_minID; |         this->m_minID = record->GetID() < this->m_minID ? record->GetID() : this->m_minID; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     auto recordsById = SMemAlloc(sizeof(void*) * (this->m_maxID - this->m_minID + 1), __FILE__, __LINE__, 0x0); |     auto recordsById = SMemAlloc(sizeof(void*) * (this->m_maxID - this->m_minID + 1), __FILE__, __LINE__, 0x0); | ||||||
| @ -163,7 +163,7 @@ void WowClientDB<T>::LoadRecords(SFile* f, const char* filename, int32_t linenum | |||||||
| 
 | 
 | ||||||
|     for (uint32_t i = 0; i < this->m_numRecords; i++) { |     for (uint32_t i = 0; i < this->m_numRecords; i++) { | ||||||
|         auto record = &this->m_records[i]; |         auto record = &this->m_records[i]; | ||||||
|         auto id = record->m_ID - this->m_minID; |         auto id = record->GetID() - this->m_minID; | ||||||
|         this->m_recordsById[id] = record; |         this->m_recordsById[id] = record; | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -5,6 +5,18 @@ const char* AchievementRec::GetFilename() { | |||||||
|     return "DBFilesClient\\Achievement.dbc"; |     return "DBFilesClient\\Achievement.dbc"; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | uint32_t AchievementRec::GetNumColumns() { | ||||||
|  |     return 62; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | uint32_t AchievementRec::GetRowSize() { | ||||||
|  |     return 248; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | int32_t AchievementRec::GetID() { | ||||||
|  |     return this->m_ID; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| bool AchievementRec::Read(SFile* f, const char* stringBuffer) { | bool AchievementRec::Read(SFile* f, const char* stringBuffer) { | ||||||
|     uint32_t titleOfs[16]; |     uint32_t titleOfs[16]; | ||||||
|     uint32_t titleMask; |     uint32_t titleMask; | ||||||
|  | |||||||
| @ -7,9 +7,6 @@ class SFile; | |||||||
| 
 | 
 | ||||||
| class AchievementRec { | class AchievementRec { | ||||||
|     public: |     public: | ||||||
|         static constexpr uint32_t columnCount = 62; |  | ||||||
|         static constexpr uint32_t rowSize = 248; |  | ||||||
| 
 |  | ||||||
|         int32_t m_ID; |         int32_t m_ID; | ||||||
|         int32_t m_faction; |         int32_t m_faction; | ||||||
|         int32_t m_instanceID; |         int32_t m_instanceID; | ||||||
| @ -20,12 +17,16 @@ class AchievementRec { | |||||||
|         int32_t m_points; |         int32_t m_points; | ||||||
|         int32_t m_uiOrder; |         int32_t m_uiOrder; | ||||||
|         int32_t m_flags; |         int32_t m_flags; | ||||||
|         uint32_t m_iconID; |         int32_t m_iconID; | ||||||
|         const char* m_reward; |         const char* m_reward; | ||||||
|         int32_t m_minimumCriteria; |         int32_t m_minimumCriteria; | ||||||
|         int32_t m_sharesCriteria; |         int32_t m_sharesCriteria; | ||||||
| 
 | 
 | ||||||
|         static const char* GetFilename(); |         static const char* GetFilename(); | ||||||
|  |         static uint32_t GetNumColumns(); | ||||||
|  |         static uint32_t GetRowSize(); | ||||||
|  | 
 | ||||||
|  |         int32_t GetID(); | ||||||
|         bool Read(SFile* f, const char* stringBuffer); |         bool Read(SFile* f, const char* stringBuffer); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -5,6 +5,18 @@ const char* Cfg_CategoriesRec::GetFilename() { | |||||||
|     return "DBFilesClient\\Cfg_Categories.dbc"; |     return "DBFilesClient\\Cfg_Categories.dbc"; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | uint32_t Cfg_CategoriesRec::GetNumColumns() { | ||||||
|  |     return 21; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | uint32_t Cfg_CategoriesRec::GetRowSize() { | ||||||
|  |     return 84; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | int32_t Cfg_CategoriesRec::GetID() { | ||||||
|  |     return this->m_ID; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| bool Cfg_CategoriesRec::Read(SFile* f, const char* stringBuffer) { | bool Cfg_CategoriesRec::Read(SFile* f, const char* stringBuffer) { | ||||||
|     uint32_t nameOfs[16]; |     uint32_t nameOfs[16]; | ||||||
|     uint32_t nameMask; |     uint32_t nameMask; | ||||||
|  | |||||||
| @ -7,17 +7,18 @@ class SFile; | |||||||
| 
 | 
 | ||||||
| class Cfg_CategoriesRec { | class Cfg_CategoriesRec { | ||||||
|     public: |     public: | ||||||
|     static constexpr uint32_t columnCount = 21; |         int32_t m_ID; | ||||||
|     static constexpr uint32_t rowSize = 84; |         int32_t m_localeMask; | ||||||
|  |         int32_t m_createCharsetMask; | ||||||
|  |         int32_t m_flags; | ||||||
|  |         const char *m_name; | ||||||
| 
 | 
 | ||||||
|     uint32_t m_ID; |         static const char* GetFilename(); | ||||||
|     uint32_t m_localeMask; |         static uint32_t GetNumColumns(); | ||||||
|     uint32_t m_createCharsetMask; |         static uint32_t GetRowSize(); | ||||||
|     uint32_t m_flags; |  | ||||||
|     const char *m_name; |  | ||||||
| 
 | 
 | ||||||
|     static const char* GetFilename(); |         int32_t GetID(); | ||||||
|     bool Read(SFile* f, const char* stringBuffer); |         bool Read(SFile* f, const char* stringBuffer); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| #endif | #endif | ||||||
|  | |||||||
| @ -52,7 +52,7 @@ void CRealmList::UpdateList() { | |||||||
|         for (int32_t categoryIndex = 0; categoryIndex < CRealmList::s_categories.Count(); categoryIndex++) { |         for (int32_t categoryIndex = 0; categoryIndex < CRealmList::s_categories.Count(); categoryIndex++) { | ||||||
|             auto realmCategory = CRealmList::s_categories[categoryIndex]; |             auto realmCategory = CRealmList::s_categories[categoryIndex]; | ||||||
| 
 | 
 | ||||||
|             if (realmInfo->category != realmCategory->m_category->m_ID) { |             if (realmInfo->category != realmCategory->m_category->GetID()) { | ||||||
|                 continue; |                 continue; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
| @ -76,7 +76,7 @@ void CRealmList::UpdateList() { | |||||||
|     // TODO sort realm list
 |     // TODO sort realm list
 | ||||||
| 
 | 
 | ||||||
|     for (int32_t i = 0; i < CRealmList::s_categories.Count(); i++) { |     for (int32_t i = 0; i < CRealmList::s_categories.Count(); i++) { | ||||||
|         if (CRealmList::s_categories[i]->m_category->m_ID == category) { |         if (CRealmList::s_categories[i]->m_category->GetID() == category) { | ||||||
|             CRealmList::s_selectedCategory = i; |             CRealmList::s_selectedCategory = i; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 fallenoak
						fallenoak