mirror of
				https://github.com/AxioDL/PrimeWorldEditor.git
				synced 2025-10-26 19:50:34 +00:00 
			
		
		
		
	CWorldCooker: Prevent signed overflow in CookMLVL
Even if all 32 bits aren't used, this still eliminates a sign-conversion warning from int to uint64.`
This commit is contained in:
		
							parent
							
								
									1d54df7185
								
							
						
					
					
						commit
						9d21516296
					
				| @ -4,7 +4,7 @@ | |||||||
| #include "Core/GameProject/DependencyListBuilders.h" | #include "Core/GameProject/DependencyListBuilders.h" | ||||||
| #include <Common/Log.h> | #include <Common/Log.h> | ||||||
| 
 | 
 | ||||||
| const bool gkForceDisableCompression = false; | constexpr bool gkForceDisableCompression = false; | ||||||
| 
 | 
 | ||||||
| CAreaCooker::CAreaCooker() = default; | CAreaCooker::CAreaCooker() = default; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -222,13 +222,13 @@ bool CWorldCooker::CookMLVL(CWorld *pWorld, IOutputStream& rMLVL) | |||||||
|         LayerNameOffsets.push_back(LayerNames.size()); |         LayerNameOffsets.push_back(LayerNames.size()); | ||||||
|         rMLVL.WriteLong(rArea.Layers.size()); |         rMLVL.WriteLong(rArea.Layers.size()); | ||||||
| 
 | 
 | ||||||
|         uint64 LayerActiveFlags = -1; |         uint64 LayerActiveFlags = UINT64_MAX; | ||||||
| 
 | 
 | ||||||
|         for (uint32 iLyr = 0; iLyr < rArea.Layers.size(); iLyr++) |         for (uint32 iLyr = 0; iLyr < rArea.Layers.size(); iLyr++) | ||||||
|         { |         { | ||||||
|             CWorld::SArea::SLayer& rLayer = rArea.Layers[iLyr]; |             CWorld::SArea::SLayer& rLayer = rArea.Layers[iLyr]; | ||||||
|             if (!rLayer.Active) |             if (!rLayer.Active) | ||||||
|                 LayerActiveFlags &= ~(1 << iLyr); |                 LayerActiveFlags &= ~(UINT64_C(1) << iLyr); | ||||||
| 
 | 
 | ||||||
|             LayerNames.push_back(rLayer.LayerName); |             LayerNames.push_back(rLayer.LayerName); | ||||||
|             LayerStateIDs.push_back(rLayer.LayerStateID); |             LayerStateIDs.push_back(rLayer.LayerStateID); | ||||||
|  | |||||||
| @ -9,14 +9,14 @@ namespace NPropertyMap | |||||||
| namespace | namespace | ||||||
| { | { | ||||||
| /** Path to the property map file */ | /** Path to the property map file */ | ||||||
| const char* gpkLegacyMapPath = "templates/PropertyMapLegacy.xml"; | constexpr char gpkLegacyMapPath[] = "templates/PropertyMapLegacy.xml"; | ||||||
| const char* gpkMapPath = "templates/PropertyMap.xml"; | constexpr char gpkMapPath[] = "templates/PropertyMap.xml"; | ||||||
| 
 | 
 | ||||||
| /** Whether to do name lookups from the legacy map */ | /** Whether to do name lookups from the legacy map */ | ||||||
| const bool gkUseLegacyMapForNameLookups = false; | constexpr bool gkUseLegacyMapForNameLookups = false; | ||||||
| 
 | 
 | ||||||
| /** Whether to update names in the legacy map */ | /** Whether to update names in the legacy map */ | ||||||
| const bool gkUseLegacyMapForUpdates = false; | constexpr bool gkUseLegacyMapForUpdates = false; | ||||||
| 
 | 
 | ||||||
| /** Whether the map is dirty (has unsaved changes */ | /** Whether the map is dirty (has unsaved changes */ | ||||||
| bool gMapIsDirty = false; | bool gMapIsDirty = false; | ||||||
| @ -150,7 +150,7 @@ void LoadMap() | |||||||
|     ASSERT(!gMapIsLoaded); |     ASSERT(!gMapIsLoaded); | ||||||
|     debugf("Loading property map"); |     debugf("Loading property map"); | ||||||
| 
 | 
 | ||||||
|     if (gkUseLegacyMapForNameLookups) |     if constexpr (gkUseLegacyMapForNameLookups) | ||||||
|     { |     { | ||||||
|         CXMLReader Reader(gDataDir + gpkLegacyMapPath); |         CXMLReader Reader(gDataDir + gpkLegacyMapPath); | ||||||
|         ASSERT(Reader.IsValid()); |         ASSERT(Reader.IsValid()); | ||||||
| @ -199,7 +199,7 @@ void SaveMap(bool Force) | |||||||
| 
 | 
 | ||||||
|     if (gMapIsDirty || Force) |     if (gMapIsDirty || Force) | ||||||
|     { |     { | ||||||
|         if (gkUseLegacyMapForUpdates) |         if constexpr (gkUseLegacyMapForUpdates) | ||||||
|         { |         { | ||||||
|             CXMLWriter Writer(gDataDir + gpkLegacyMapPath, "PropertyMap"); |             CXMLWriter Writer(gDataDir + gpkLegacyMapPath, "PropertyMap"); | ||||||
|             ASSERT(Writer.IsValid()); |             ASSERT(Writer.IsValid()); | ||||||
| @ -235,7 +235,7 @@ const char* GetPropertyName(IProperty* pInProperty) | |||||||
| { | { | ||||||
|     ConditionalLoadMap(); |     ConditionalLoadMap(); | ||||||
| 
 | 
 | ||||||
|     if (gkUseLegacyMapForNameLookups) |     if constexpr (gkUseLegacyMapForNameLookups) | ||||||
|     { |     { | ||||||
|         const auto MapFind = gLegacyNameMap.find(pInProperty->ID()); |         const auto MapFind = gLegacyNameMap.find(pInProperty->ID()); | ||||||
|         return MapFind == gLegacyNameMap.cend() ? "Unknown" : *MapFind->second; |         return MapFind == gLegacyNameMap.cend() ? "Unknown" : *MapFind->second; | ||||||
| @ -327,7 +327,7 @@ void RetrieveXMLsWithProperty(uint32 ID, const char* pkTypeName, std::set<TStrin | |||||||
| /** Updates the name of a given property in the map */ | /** Updates the name of a given property in the map */ | ||||||
| void SetPropertyName(uint32 ID, const char* pkTypeName, const char* pkNewName) | void SetPropertyName(uint32 ID, const char* pkTypeName, const char* pkNewName) | ||||||
| { | { | ||||||
|     if (gkUseLegacyMapForUpdates) |     if constexpr (gkUseLegacyMapForUpdates) | ||||||
|     { |     { | ||||||
|         auto Iter = gLegacyNameMap.find(ID); |         auto Iter = gLegacyNameMap.find(ID); | ||||||
| 
 | 
 | ||||||
| @ -475,7 +475,7 @@ void RegisterProperty(IProperty* pProperty) | |||||||
|     SNameKey Key = CreateKey(pProperty); |     SNameKey Key = CreateKey(pProperty); | ||||||
|     auto MapFind = gNameMap.find(Key); |     auto MapFind = gNameMap.find(Key); | ||||||
| 
 | 
 | ||||||
|     if (gkUseLegacyMapForNameLookups) |     if constexpr (gkUseLegacyMapForNameLookups) | ||||||
|     { |     { | ||||||
|         // If we are using the legacy map, gNameMap may be empty. We need to retrieve the name
 |         // If we are using the legacy map, gNameMap may be empty. We need to retrieve the name
 | ||||||
|         // from the legacy map, and create an entry in gNameMap with it.
 |         // from the legacy map, and create an entry in gNameMap with it.
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user