Browse Source

Merge pull request #1848 from Nordsoft91/editor-fix

Fix map editor crash with cutting random town
Ivan Savenko 2 years ago
parent
commit
1cb0c6b270
1 changed files with 10 additions and 7 deletions
  1. 10 7
      lib/mapObjects/CGTownInstance.h

+ 10 - 7
lib/mapObjects/CGTownInstance.h

@@ -256,15 +256,18 @@ public:
 		h & townAndVis;
 		h & townAndVis;
 		BONUS_TREE_DESERIALIZATION_FIX
 		BONUS_TREE_DESERIALIZATION_FIX
 
 
-		vstd::erase_if(builtBuildings, [this](BuildingID building) -> bool
+		if(town)
 		{
 		{
-			if(!town->buildings.count(building) ||  !town->buildings.at(building))
+			vstd::erase_if(builtBuildings, [this](BuildingID building) -> bool
 			{
 			{
-				logGlobal->error("#1444-like issue in CGTownInstance::serialize. From town %s at %s removing the bogus builtBuildings item %s", name, pos.toString(), building);
-				return true;
-			}
-			return false;
-		});
+				if(!town->buildings.count(building) || !town->buildings.at(building))
+				{
+					logGlobal->error("#1444-like issue in CGTownInstance::serialize. From town %s at %s removing the bogus builtBuildings item %s", name, pos.toString(), building);
+					return true;
+				}
+				return false;
+			});
+		}
 
 
 		h & overriddenBuildings;
 		h & overriddenBuildings;